我在xml的datatable中放了一些值,我有重复的值,还有一些区分大小写的值
例如:猫,大象,接手,程序,一些,程序,猫,狗
所以我使用了一个像
这样的条件if (!(FindRow.Rows.Contains(val)))
{
FindRow.Rows.Add(val);
}
我希望我的数据表同时具有Program
和PROGRAM
,并且不应该有两个cat值,但它只需要一个program
答案 0 :(得分:1)
我至少可以看到两种方法:
准备HashSet<string>
,每次将项目添加到DataTable
时,将相同字符串的小写版本添加到集合中。然后,每次要添加新行时,请检查表格的设置内容。
var set = new HashSet<string>();
if (!(set.Contains(val.ToLower())))
{
FindRow.Rows.Add(val);
set.Add(val.ToLower());
}
您可以使用LINQ执行更复杂的查询:
if (!(FindRow.Rows.AsEnumerable().Any(r => r.Field<string>("YourKeyColumnName").ToLower() == val.ToLower())))
{
FindRow.Rows.Add(val);
}
您需要System.Data.DataSetExtensions.dll
汇总引用并在文件顶部using System.Data.DataSetExtensions
才能使其正常工作。