将 DataTable 转换为字典 C#

     2023-03-16     118

关键词:

【中文标题】将 DataTable 转换为字典 C#【英文标题】:Transform a DataTable into Dictionary C# 【发布时间】:2013-11-11 20:08:14 【问题描述】:

我想知道如何将 DataTable 转换为 Dictionary。我做了这样的事情。

using System.Linq;

internal Dictionary<string,object> GetDict(DataTable dt)

    return dt.AsEnumerable()
      .ToDictionary<string, object>(row => row.Field<string>(0),
                                row => row.Field<object>(1));

但我明白了:

System.Data.EnumerableRowCollection 不包含“ToDictionary”的定义和最佳扩展方法重载“System.Linq.Parallel.Enumerable.ToDictionary(System.Linq.ParallelQuery, System.Func, System.Collections.Generic. IEqualityComparer)' 有一些无效的参数ch

我该如何解决这个问题?

谢谢

【问题讨论】:

请发布完整的错误信息。 我添加了完整的错误信息 【参考方案1】:

我找到了解决方案,但不知道为什么。我编辑了我的问题,完成了代码,只是为了清楚我在做什么,然后我改成了这个

    internal Dictionary<string, object> GetDict(DataTable dt)
    
        Dictionary<String, Object> dic = dt.AsEnumerable().ToDictionary(row => row.Field<String>(0), row => row.Field<Object>(1));
        return dic;
    

【讨论】:

【参考方案2】:

ToDictionary 期望 IEnumberable&lt;T&gt; 作为第一种类型...您告诉它这是一个错误的字符串,它是 IEnumerable&lt;DataRow&gt;

指定类型让你感到困惑...试试这个...

internal Dictionary<string,object> GetDict(DataTable dt)

    return dt.AsEnumerable()
      .ToDictionary(row => row.Field<string>(0),
                                row => row.Field<object>(1));

【讨论】:

【参考方案3】:

我认为这会对你有所帮助:

            DataTable dt = new DataTable();
            dt.Columns.Add("Column1");
            dt.Columns.Add("Column2");
            dt.Rows.Add(1, "first");
            dt.Rows.Add(2, "second");
            var dictionary = dt.Rows.OfType<DataRow>().ToDictionary(d => d.Field<string>(0), v => v.Field<object>(1));

【讨论】:

编译器错误:“DataRow”不包含“Field”的定义,并且没有可访问的扩展方法“Field”接受... 需要在.NET Core中安装System.Data.DataSetExtensions.dll,都不错【参考方案4】:

泛型方法ToDictionary 有3 个参数。你离开了一个,所以它不知道该怎么办。如果要指定所有参数,则为&lt;DataRow, string, object&gt;

internal Dictionary<string,object> GetDict(DataTable dt)

    return dt.AsEnumerable()
      .ToDictionary<DataRow, string, object>(row => row.Field<string>(0),
                                row => row.Field<object>(1));

当然,如果你不使用它们,编译器可以推断类型,所以你不会得到错误。

【讨论】:

+1,是的,这是主要原因,更多详情ToDictionary<TSource, TKey, TElement> @Ilaria 您必须以一种或另一种方式将其转换为可枚举,否则您无法使用 Linq。另一种方法是dt.Rows.Cast&lt;DataTable&gt;()【参考方案5】:

所有之前的答案都没有帮助我,所以我这样做了:

myList = dt.AsEnumerable()
.ToDictionary<DataRow, string, string>(row => row[0].ToString(),
                                       row => row[1].ToString()); 

效果很好!

【讨论】:

【参考方案6】:

我更喜欢这种方法:

public static List<Dictionary<string, string>> GetDataTableDictionaryList(DataTable dt)

    return dt.AsEnumerable().Select(
        row => dt.Columns.Cast<DataColumn>().ToDictionary(
            column => column.ColumnName,
            column => row[column].ToString()
        )).ToList();

之所以如此,是因为这段代码还可以通过调用ToString方法来处理布尔值或其他数据类型。

请注意,这会返回一个字典列表,如果您有每一行的键,您可以将其修改为字典字典。

遍历 bool 列可能如下所示:

var list = GetDataTableDictionaryList(dt);

foreach (var row in list)

    if (row["Selected"].Equals("true", StringComparison.OrdinalIgnoreCase))
    
        // do something
    

【讨论】:

【参考方案7】:

给定的解决方案假设只有 2 列。 如果你想要多列表示,你需要一个字典列表

class Program

    static void Main(string[] args)
    
        DataTable dt = new DataTable();
        dt.Columns.Add("Column1");
        dt.Columns.Add("Column2");
        dt.Columns.Add("Column3");
        dt.Rows.Add(1, "first", "A");
        dt.Rows.Add(2, "second", "B");

        var dictTable = DataTableToDictionaryList(dt);
        var rowCount = dictTable.Count;
        var colCount = dictTable[0].Count;

        //Linq version
        var dictTableFromLinq = dt.AsEnumerable().Select(
                // ...then iterate through the columns...  
                row => dt.Columns.Cast<DataColumn>().ToDictionary(
                    // ...and find the key value pairs for the dictionary  
                    column => column.ColumnName,    // Key  
                    column => row[column] as string // Value  
                    )
                ).ToList();
    

    public static List<Dictionary<string, object>> DataTableToDictionaryList(DataTable dt)
    
        var result = new List<Dictionary<string, object>>();
        //or var result = new List<Dictionary<string, string>>();

        foreach (DataRow row in dt.Rows)
        
            var dictRow = new Dictionary<string, object>();
            foreach (DataColumn col in dt.Columns)
            
                dictRow.Add(col.ColumnName, row[col]);
                //or dictRow.Add(col.ColumnName, row[col].ToString());
            

            result.Add(dictRow);
        

        return result;
    
  

【讨论】:

【参考方案8】:

视觉基础 使用sql加载数据表并创建字典

    Dim SalesRep As New System.Collections.Generic.Dictionary(Of String, String)(StringComparer.InvariantCultureIgnoreCase)
    Using tbl As New Data.DataTable("SalesRep")
        SqlCommand.CommandText = "Select Initial,FullName from QB_SalesRep"
        tbl.Load(SqlCommand.ExecuteReader())
        ' --- Option ONE use the array to iterate
        Array.ForEach(tbl.Rows.Cast(Of Data.DataRow).ToArray(),
                      Sub(f)
                          SalesRep.Add(f.ItemAsString("Initial"), f.ItemAsString("FullName"))
                      End Sub)
        ' --- Option TWO use plain linq to create the dictionary
        SalesRep = tbl.Rows _
            .Cast(Of Data.DataRow) _
            .AsEnumerable() _
            .ToDictionary(Function(f) f.Item("Initial").toString(), Function(f) f.Item("FullName").toString)
    End Using

【讨论】:

c#将linq数据集转换为datatable

C#将LINQ数据集转换为Datatable1.方法一:(测试可用)//通过一个公共类将LINQ数据集转换为datatablepublic DataTable LINQToDataTable<T>(IEnumerable<T>varlist){    DataTable dtReturn= ne 查看详情

将字典转换为 c# 对象

】将字典转换为c#对象【英文标题】:ConvertDictionarytoc#object【发布时间】:2021-06-0616:06:41【问题描述】:我有一个嵌套字典对象输出,如下所示"name":"test","id":1,"parent":"name":"test1","id":2,"parent":"name":"test2","id":3,"parent":"name":"test3","id":... 查看详情

将具有多个嵌套数组的通用 Json 转换为 Datatable C#

】将具有多个嵌套数组的通用Json转换为DatatableC#【英文标题】:ConvertgenericJsonwithmultiplenestedarraytoaDatatableC#【发布时间】:2022-01-0419:39:09【问题描述】:我需要帮助,我需要一个接收Json并返回Datatable的函数,任何输入都可以是Json... 查看详情

如何在 C# 中将 DataTable 转换为通用列表 [重复]

】如何在C#中将DataTable转换为通用列表[重复]【英文标题】:HowtoConvertDataTabletoGenericListinC#[duplicate]【发布时间】:2016-12-1608:54:08【问题描述】:我需要将C#DataTable转换为通用集合列表DataTableColumnsRespectively1.EmpId(thisisIntDataType)2.EmpNam... 查看详情

聚合 C# 数据集时,如何将 DataSet 转换为 .Load() 的 DataTable 数组?

】聚合C#数据集时,如何将DataSet转换为.Load()的DataTable数组?【英文标题】:WhenaggregatingC#datasets,howdoIconvertaDataSetintoanDataTableArrayfor.Load()?【发布时间】:2013-05-0401:30:42【问题描述】:我正在使用.NET4.0。我正在尝试将许多具有相同... 查看详情

C# 将字典转换为类似字符串的 CSV

】C#将字典转换为类似字符串的CSV【英文标题】:C#convertdictionaryintoCSVlikestring【发布时间】:2021-05-1601:19:25【问题描述】:我有一本字典Dictionary&lt;string,List&lt;string&gt;&gt;我想按字母顺序按键排序并将其转换为可以写... 查看详情

如何在 DataTable 中的 .net C# 中将 0 转换为“-”

】如何在DataTable中的.netC#中将0转换为“-”【英文标题】:HowcanIConvert0to\'-\'in.netC#inADataTable【发布时间】:2021-06-2416:52:08【问题描述】:我得到一个表格,其中有几列包含数字。我想要的是在数字为0的情况下显示“-”。我尝试... 查看详情

c#无法将类型为“system.byte[]”的对象强制转换为类型“system.data.datatable

...matter.Serialize(bytememorystream,strbyte);bytememorystream.Position=0;dt=(DataTable)binaryformatter.Deserialize(bytememorystream) 查看详情

如何将 Dictionary 转换为 DataTable? (C#)

】如何将Dictionary转换为DataTable?(C#)【英文标题】:HowcanyouconvertaDictionaryintoaDataTable?(C#)【发布时间】:2021-02-0618:35:06【问题描述】:你怎么能把任意一个Dictionary变成一个DataTable?我必须完成这项任务,以便在我的一个应用... 查看详情

如何将 List<string> 转换为 IEnumerable<ServiceReference.datatable> C# Silverlight WCF RIA Serv

】如何将List<string>转换为IEnumerable<ServiceReference.datatable>C#SilverlightWCFRIAServicesLINQtoSQL【英文标题】:HowtoconvertaList<string>toanIEnumerable<ServiceReference.datatable>C#SilverlightWCFRIAServices 查看详情

在 C# 中将数据表转换为 JSON

】在C#中将数据表转换为JSON【英文标题】:ConvertdatatabletoJSONinC#【发布时间】:2013-06-2804:38:25【问题描述】:我想从数据库中获取记录到DataTable。然后将DataTable转换为JSON对象。将JSON对象返回给我的JavaScript函数。我通过调用使用t... 查看详情

将 JSON 转换为字典?

】将JSON转换为字典?【英文标题】:ConvertJSONtodictionary?【发布时间】:2018-07-0401:11:20【问题描述】:我在将JSON转换为字符串字典时遇到了问题。这是我试图在C#中转换成字典的一些JSON文本。"game":"players":"limit":"10000","ip_limit":"4"... 查看详情

c#常用的datable转换为json,以及json转换为datatable操作方法

#region DataTable转换为Json字符串实例方法///<summary>///GetClassTypeJosn的摘要说明///</summary>publicclassGetClassTypeJosn:IHttpHandler{   ///<summary>   ///文件名:D 查看详情

c#将datatable转换成list的方法

本文实例讲述了C#将DataTable转换成list及数据分页的方法。分享给大家供大家参考。具体如下:///<summary>  ///酒店评论列表-分页 ///</summary> ///<paramname="userId"></param> ///<paramname="pageIndex 查看详情

在 C# 中将 DataTable 转换为通用列表

】在C#中将DataTable转换为通用列表【英文标题】:ConvertDataTabletoGenericListinC#【发布时间】:2010-11-0508:47:13【问题描述】:免责声明:我知道它在SO的很多地方都被问到过。我的查询有点不同。编码语言:C#3.5我有一个名为cardsTable... 查看详情

c#中这样将dataset转换为datatable?

...t;);//自己写的方法intr=ds.Tables[0].Rows.Count;//取出的数目=6条DataTabledt=newDataTable();dt=????//把SQL语句查询出来的全部结果显示在dt上面..dt=ds.Tables[0];是不对的我需要的是dt的值为sql查询出来的数据.怎么获得你既然要ds.Tables[0]那你的DT就... 查看详情

c#将datatable数据源转换成实体类

1usingSystem;2usingSystem.Collections.Generic;3usingSystem.Data;4usingSystem.Reflection;56///<summary>7///将DataTable数据源转换成实体类8///</summary>9///<typeparamname="T">实体</typeparam> 查看详情

C# 在 .NET 1.1 中将 DataView 转换为表(DataTable)

】C#在.NET1.1中将DataView转换为表(DataTable)【英文标题】:C#ConvertDataViewtoTable(DataTable)in.NET1.1【发布时间】:2017-10-3018:01:36【问题描述】:我有一个设置了行过滤器的数据视图:DataViewdv=ds.Tables[0].DefaultView;dv.RowFilter="heremyfilter";过... 查看详情