C#去除DataTable重复数据的三种方法

标题:C#去除DataTable重复数据的三种方法

方法一:使用Linq去重

步骤:

1.将DataTable转换为IEnumerable对象;

2.使用Linq的Distinct方法去重;

3.将结果转换为DataTable对象。

示例:

DataTable table = new DataTable();
// 假设table中包含重复数据
IEnumerable<DataRow> rows = table.AsEnumerable();
IEnumerable<DataRow> distinctRows = rows.Distinct(DataRowComparer.Default);
DataTable resultTable = distinctRows.CopyToDataTable();

方法二:使用DefaultView去重

步骤:

1.给DataTable添加主键;

2.使用DefaultView的ToTable方法去重。

示例:

DataTable table = new DataTable();
// 添加主键
table.PrimaryKey = new DataColumn[] { table.Columns["column1"], table.Columns["column2"] };
// 假设table中包含重复数据
DataTable distinctTable = table.DefaultView.ToTable(true);

方法三:使用Hashset去重

步骤:

1.定义Hashset对象;

2.循环遍历DataTable的数据行,使用Hashset的Add方法去重;

3.将结果转换为DataTable对象。

示例:

DataTable table = new DataTable();
// 假设table中包含重复数据
HashSet<string> hashset = new HashSet<string>();
foreach (DataRow row in table.Rows)
{
    string key = row["column1"].ToString() + row["column2"].ToString();
    if (!hashset.Add(key))
    {
        row.Delete();
    }
}
table.AcceptChanges();

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C#去除DataTable重复数据的三种方法 - Python技术站

(0)
上一篇 2023年6月2日
下一篇 2023年6月2日

相关文章

  • WPF的控件字符串内容使用StringFormat进行字符串转换

    在WPF中TextBlock的Text有时内容只需要改变个别数字,而不需要所以内容都修改,这时候就要使用StringFormat, 如: <TextBlock Text=”I have xxx friends”/> 这里面的xxx是个变量,那在Binding时应该怎样写呢 <TextBlock Text=”{Binding FirendNu…

    C# 2023年4月18日
    00
  • C#通过GET/POST方式发送Http请求

    下面我将为你详细讲解“C#通过GET/POST方式发送HTTP请求”的完整攻略。 1. 使用HttpWebRequest类发送GET请求 发送GET请求需要使用HttpWebRequest类。下面是发送GET请求的示例代码: string url = "https://example.com/api/"; HttpWebRequest r…

    C# 2023年5月31日
    00
  • C# 9 新特性之增强的foreach详解

    C# 9 新特性之增强的 foreach 详解 简介 在 C# 9 中,foreach 循环得到了一些增强,包括更好的性能,支持使用 ref 局部变量以及对 IAsyncEnumerable 类型的异步迭代支持。 更好的性能 在 C# 9 中,foreach 的性能得到了提升。它会通过对枚举器对象的优化,减少一些额外的开销,以获得更好的性能。 ref 局部变…

    C# 2023年6月6日
    00
  • WPF实现上下滚动字幕效果

    WPF实现上下滚动字幕效果 在 WPF 中,实现上下滚动字幕效果通常可以使用 TranslateTransform 和 DoubleAnimation 实现。具体步骤如下: 步骤一:创建外层容器 首先,我们需要创建一个外层容器,用于包含字幕元素。这个容器可以是一个 StackPanel 或 Canvas,根据项目实际需求而定。这里我们使用 StackPane…

    C# 2023年6月1日
    00
  • c# 网址压缩简单实现短网址

    下面是C#网址压缩简单实现短网址的完整攻略: 1. 短网址原理 短网址是将长的url经过特殊算法处理,缩短成几个字符,方便用户记忆、分享、输入等。短网址生成的过程包含以下几个步骤: 生成长的url 将url转换为数字 将数字进行压缩,生成短网址 将短网址与url映射存储到数据库 2. 算法原理 常用的短网址算法有以下几种: 哈希算法 随机数算法 自增序列算法…

    C# 2023年6月7日
    00
  • JavaScript ESLint插件保姆级使用教程

    JavaScript ESLint插件保姆级使用教程 1. 什么是ESLint ESLint是一个可扩展的JavaScript代码检查工具。它可以检查代码中的语法错误,提供一致的代码风格,并可以检测代码中的潜在问题。ESLint 可以配置以满足您的特定需求。ESLint内置了很多规则,您也可以通过使用插件来添加自定义规则。 2. 安装ESLint 2.1 安…

    C# 2023年5月15日
    00
  • C# / VB.NET 在PPT中创建、编辑PPT SmartArt图形的方法详解

    C# / VB.NET 在PPT中创建、编辑PPT SmartArt图形的方法详解 什么是Office SmartArt? Office SmartArt 是微软Office套件中的一种图形类型,它可以帮助用户在较短的时间内创建具有高质量的信息图形。它的能力不仅限于流程图和组织结构图,还包括算法图、漏斗图、阶段图、矩阵图、金字塔图等不同种类的图形。 如何在C…

    C# 2023年6月3日
    00
  • git 将本地文件(夹)上传到gitee指定分支的处理方法

    如果您想将本地文件或文件夹上传到Gitee指定分支,可以按照以下几个步骤进行。 步骤1:创建本地Git仓库 如果您已经有了本地仓库,请跳过这一步骤。 在本地计算机上创建一个文件夹,然后进入该文件夹,使用以下命令初始化本地Git仓库。 git init 这将在目录中创建一个.git文件夹,其中包含Git配置和版本历史记录。 步骤2:添加文件到Git仓库 将您要…

    C# 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部