本篇文章為大家展示了怎么在C#中去除DataTable中的重復(fù)數(shù)據(jù),內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
DataView.ToTable 方法
.NET Framework 2.0
其根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個(gè)新的DataTable。
重載列表
名稱 | 說明 |
---|---|
DataView.ToTable () | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個(gè)新的 DataTable。 由 .NET Compact Framework 支持。 |
DataView.ToTable (String) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個(gè)新的 DataTable。 由 .NET Compact Framework 支持。 |
DataView.ToTable (Boolean, String[]) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個(gè)新的 DataTable。 由 .NET Compact Framework 支持。 |
DataView.ToTable (String, Boolean, String[]) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個(gè)新的 DataTable。 由 .NET Compact Framework 支持。 |
實(shí)例代碼
public static DataTable Distinct(DataTable dt, string[] filedNames) { DataView dv = dt.DefaultView; DataTable DistTable = dv.ToTable("Dist", true, filedNames); return DistTable; }
利用for循環(huán)遍歷DataTable的數(shù)據(jù)行,利用DataTable.Select 方法判斷是否重復(fù),如果重復(fù),則利用DataTable.Rows.RemoveAt(Index)刪除重復(fù)的那一行。
具體看代碼。
代碼示例
public DataTable GetDistinctSelf(DataTable SourceDt, string filedName) { for (int i = SourceDt.Rows.Count - 2; i > 0; i--) { DataRow[] rows = SourceDt.Select(string.Format("{0}='{1}'", filedName, SourceDt.Rows[i][filedName])); if (rows.Length > 1) { SourceDt.Rows.RemoveAt(i); } } return SourceDt; }
利用雙循環(huán)遍歷(不推薦)
public DataTable GetDistinctSelf(DataTable SourceDt, string filedName) { for (int i = SourceDt.Rows.Count - 2; i > 0; i--) { string title = SourceDt.Rows[0][filedName].ToString(); for (int j = i + 1; j > 0; i--) { if (SourceDt.Rows[j][filedName].ToString() == title) { SourceDt.Rows.RemoveAt(i); } } } return SourceDt; }
上述內(nèi)容就是怎么在C#中去除DataTable中的重復(fù)數(shù)據(jù),你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。