按列对DataTable进行分组并转换为List<DataTable>
创始人
2024-11-03 01:00:43
0

以下是一个按列对DataTable进行分组并转换为List的示例代码:

using System;
using System.Data;
using System.Collections.Generic;

public class Program
{
    public static void Main()
    {
        // 创建一个示例DataTable
        DataTable dt = new DataTable();
        dt.Columns.Add("Name", typeof(string));
        dt.Columns.Add("Age", typeof(int));
        dt.Columns.Add("City", typeof(string));

        dt.Rows.Add("John", 25, "New York");
        dt.Rows.Add("Alice", 30, "London");
        dt.Rows.Add("Bob", 35, "Paris");
        dt.Rows.Add("Emily", 28, "Tokyo");
        dt.Rows.Add("Mike", 32, "New York");
        dt.Rows.Add("Tom", 29, "London");

        // 按列进行分组并转换为List
        List groupedTables = GroupByColumn(dt, "City");

        // 输出每个分组的DataTable
        foreach (DataTable group in groupedTables)
        {
            Console.WriteLine("Group: " + group.TableName);
            foreach (DataRow row in group.Rows)
            {
                Console.WriteLine(row["Name"] + "\t" + row["Age"] + "\t" + row["City"]);
            }
            Console.WriteLine();
        }
    }

    public static List GroupByColumn(DataTable dt, string columnName)
    {
        // 创建一个Dictionary用于保存分组后的DataTable
        Dictionary groupedTables = new Dictionary();

        foreach (DataRow row in dt.Rows)
        {
            // 获取当前行指定列的值
            object value = row[columnName];
            
            // 如果Dictionary中不存在对应的DataTable,则创建一个新的DataTable并添加到Dictionary中
            if (!groupedTables.ContainsKey(value))
            {
                DataTable newTable = dt.Clone();
                newTable.TableName = value.ToString();
                groupedTables.Add(value, newTable);
            }

            // 将当前行复制到对应的DataTable中
            groupedTables[value].ImportRow(row);
        }

        // 将Dictionary中的DataTable转换为List并返回
        List result = new List(groupedTables.Values);
        return result;
    }
}

上述代码首先创建了一个示例的DataTable,并包含三列:Name、Age和City。然后使用GroupByColumn方法按照City列进行分组,将分组后的DataTable保存到一个Dictionary中。最后将Dictionary中的DataTable转换为List,并进行输出展示。

相关内容

热门资讯

此事引发广泛关注"功... 此事引发广泛关注"功夫川麻小程序有挂吗"一贯存在有辅助神器(哔哩哔哩)运功夫川麻小程序有挂吗辅助工具...
透视了解"越乡游义乌... 透视了解"越乡游义乌透视软件"切实是有辅助教程(哔哩哔哩);1、越乡游义乌透视软件模拟器是什么优化,...
黑科技辅助挂"乐酷辅... 黑科技辅助挂"乐酷辅助"一贯是有辅助插件(哔哩哔哩)1、任何乐酷辅助透视是真的假的的玩家都可以机会成...
据监测"新518互游... 据监测"新518互游脚本"切实真的是有辅助攻略(哔哩哔哩)1、任何新518互游脚本透视是真的假的的玩...
透视好友"葫芦娃七子... 透视好友"葫芦娃七子连心攻略"好像真的是有辅助插件(哔哩哔哩)进入游戏-大厅左侧-新手福利-激活码辅...
透视总结"友友联盟免... 透视总结"友友联盟免费辅助器"确实是真的有辅助攻略(哔哩哔哩)1、友友联盟免费辅助器脚本辅助下载、友...
值得注意的是"广西友... 值得注意的是"广西友乐软件辅助"真是存在有辅助器(哔哩哔哩)广西友乐软件辅助破解侠是真的助透视。每个...
透视智能ai"爱来掌... 透视智能ai"爱来掌中宝有没有挂"好像是有辅助插件(哔哩哔哩)暗藏猫腻,小编详细说明爱来掌中宝有没有...
透视好牌"佛手在线破... 透视好牌"佛手在线破解"竟然确实有辅助app(哔哩哔哩)1、每一步都需要思考,不同水平的挑战会更加具...
透视好友房"微乐智能... 透视好友房"微乐智能辅助app"果然真的有辅助器(哔哩哔哩)1、微乐智能辅助app透视辅助软件激活码...