如何在数据表中以区分大小写的方式显示

时间:2014-01-07 06:19:06

标签: c# datatable

我在xml的datatable中放了一些值,我有重复的值,还有一些区分大小写的值

  

例如:猫,大象,接手,程序,一些,程序,猫,狗

所以我使用了一个像

这样的条件
if (!(FindRow.Rows.Contains(val)))
{
   FindRow.Rows.Add(val);
}

我希望我的数据表同时具有ProgramPROGRAM,并且不应该有两个cat值,但它只需要一个program

1 个答案:

答案 0 :(得分:1)

我至少可以看到两种方法:

  1. 准备HashSet<string>,每次将项目添加到DataTable时,将相同字符串的小写版本添加到集合中。然后,每次要添加新行时,请检查表格的设置内容。

    var set = new HashSet<string>();
    
    if (!(set.Contains(val.ToLower())))
    {
       FindRow.Rows.Add(val);
       set.Add(val.ToLower());
    }
    
  2. 您可以使用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才能使其正常工作。