为了账号安全,请及时绑定邮箱和手机立即绑定

如何将DataTable拆分为多个数据表c#

如何将DataTable拆分为多个数据表c#

C#
翻翻过去那场雪 2021-07-14 17:57:00
Gender      Age    Category--------------------------------Male     |  10     |   2Female   |  15     |   1Trans    |  13     |   3Female   |  10     |   1Male     |  20     |   2我有一个具有上述值的数据表。男性 CategoryId 为 2。在上表中,共有 2 个男性行。基于类别,合并两行并分成一个单独的数据表。我需要的输出是:-数据表 1Gender      Age    Category--------------------------------Male     |  10     |   2Male     |  20     |   2数据表2Gender      Age    Category--------------------------------Female   |  15     |   1Female   |  10     |   1数据表3Gender      Age    Category--------------------------------Trans    |  13     |   3
查看完整描述

3 回答

?
斯蒂芬大帝

TA贡献1827条经验 获得超8个赞

干得好:


List<DataTable> result = DTHead.AsEnumerable()

            .GroupBy(row => row.Field<DataType>("Category"))

            .Select(g => g.CopyToDataTable())

            .ToList();


查看完整回答
反对 回复 2021-07-17
?
慕斯王

TA贡献1864条经验 获得超2个赞

var view = sourceDataTable.DefaultView;


view.RowFilter = "Category = 2";

var maleDataTable = view.ToTable();


view.RowFilter = "Category = 1";

var femaleDataTable = view.ToTable();


view.RowFilter = "Category = 3";

var transDataTable = view.ToTable();


查看完整回答
反对 回复 2021-07-17
?
元芳怎么了

TA贡献1798条经验 获得超7个赞

请参阅以下内容:


using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data;



namespace ConsoleApplication48

{

    class Program

    {

        static void Main(string[] args)

        {

            DataTable dt = new DataTable();

            dt.Columns.Add("Gender", typeof(string));

            dt.Columns.Add("Age", typeof(int));

            dt.Columns.Add("Category", typeof(int));


            dt.Rows.Add(new object[] {"Male", 10, 2});

            dt.Rows.Add(new object[] {"Female", 15, 1});

            dt.Rows.Add(new object[] {"Trans", 13, 3});

            dt.Rows.Add(new object[] {"Female", 10, 1});

            dt.Rows.Add(new object[] {"Male", 20, 2});


            DataTable dt1 = dt.AsEnumerable().Where(x => x.Field<string>("Gender") == "Male").CopyToDataTable();

            DataTable dt2 = dt.AsEnumerable().Where(x => x.Field<string>("Gender") == "Feale").CopyToDataTable();

            DataTable dt3 = dt.AsEnumerable().Where(x => x.Field<string>("Gender") == "Trans").CopyToDataTable();



        }


    }


}

这是一个更通用的解决方案,可以获取列中的每种类型:


using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data;



namespace ConsoleApplication48

{

    class Program

    {

        static void Main(string[] args)

        {

            DataTable dt = new DataTable();

            dt.Columns.Add("Gender", typeof(string));

            dt.Columns.Add("Age", typeof(int));

            dt.Columns.Add("Category", typeof(int));


            dt.Rows.Add(new object[] { "Male", 10, 2 });

            dt.Rows.Add(new object[] { "Female", 15, 1 });

            dt.Rows.Add(new object[] { "Trans", 13, 3 });

            dt.Rows.Add(new object[] { "Female", 10, 1 });

            dt.Rows.Add(new object[] { "Male", 20, 2 });


            //updated code

            string[] rowNames = dt.AsEnumerable().Select(x => x.Field<string>("Gender")).Distinct().ToArray();

            DataSet ds = new DataSet();


            foreach (string gender in rowNames)

            {

                DataTable newDt = dt.AsEnumerable().Where(x => x.Field<string>("Gender") == gender).CopyToDataTable();

                newDt.TableName = gender;

                ds.Tables.Add(newDt);


            }

        }


    }


}


查看完整回答
反对 回复 2021-07-17
  • 3 回答
  • 0 关注
  • 367 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信