C#实现DataTable数据行列转换

 更新时间:2022年04月21日 09:42:03   作者:農碼一生  
这篇文章介绍了C#实现DataTable数据行列转换的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、代码

        public static DataTable RevertRowToColumn(DataTable sourcedt)
        {
            DataTable dt = new DataTable();
            //转换后的第一列名,以后此列每行存放sourcedt对应对应的每列列名
            dt.Columns.Add("COLUMN_NAME", typeof(string));

            //第二行及以后,转换后重命名的列名,列数等于sourcedt行数
            string[] aa = new string[sourcedt.Rows.Count];
            //string[] aa = { "VLAUE_1", "VLAUE_2", "VLAUE_3", "VLAUE_4", "VLAUE_5", "VLAUE_6", "VLAUE_7", "VLAUE_8", "VLAUE_9", "VLAUE_10" };
            for (int i = 0; i < sourcedt.Rows.Count; i++)
            {
                aa[i] = "VLAUE_" + (i + 1);
            }  

            //dt添加Columns
            for (int i = 0; i < aa.Length; i++)
            {
                dt.Columns.Add(aa[i].ToString(), typeof(string));//统一按照string类型进行存放
            }

            //对sourcedt进行转换
            for (int j = 0; j < sourcedt.Columns.Count; j++)
            {
                DataRow dr = dt.NewRow();
                string column_name = sourcedt.Columns[j].ColumnName;
                dr["COLUMN_NAME"] = column_name;//把source的列名赋值给转换成行的第一列值
                for (int i = 0; i < sourcedt.Rows.Count; i++)
                {
                    string cell_value = sourcedt.Rows[i][column_name].ToString();
                    dr[i + 1] = cell_value;
                }
                dt.Rows.Add(dr);
            }
            return dt;
        }

二、结果

转置前:

转置后:

注意:此转换的每列列类型统一为:typeof(string)类型。

到此这篇关于C#实现DataTable数据行列转换的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C# 添加PDF页眉/页脚的示例代码

    C# 添加PDF页眉/页脚的示例代码

    这篇文章主要介绍了C# 添加PDF页眉/页脚的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • C#实现观察者模式(Observer Pattern)的两种方式

    C#实现观察者模式(Observer Pattern)的两种方式

    这篇文章介绍了C#实现观察者模式(Observer Pattern)的两种方式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • Winform 控件优化LayeredWindow无锯齿圆角窗体

    Winform 控件优化LayeredWindow无锯齿圆角窗体

    这篇文章主要为大家介绍了Winform 控件优化LayeredWindow实现无锯齿圆角窗体示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • 深入学习C#多线程

    深入学习C#多线程

    本文详细讲解了C#多线程编程的相关技术,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • C# 打开蓝牙设置界面的两种方法

    C# 打开蓝牙设置界面的两种方法

    这篇文章主要介绍了C# 打开蓝牙设置界面的两种方法,文中讲解非常细致,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • Unity编辑器资源导入处理函数OnPreprocessAudio用法示例

    Unity编辑器资源导入处理函数OnPreprocessAudio用法示例

    这篇文章主要为大家介绍了Unity编辑器资源导入处理函数OnPreprocessAudio用法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • c#事件使用示例详解

    c#事件使用示例详解

    这篇文章主要介绍了c#事件使用方法,下面我们利用一个例子来加深我们对事件的理解,需要的朋友可以参考下
    2014-04-04
  • C#锁住文件的操作步骤

    C#锁住文件的操作步骤

    在本篇文章里小编给大家整理的是关于C#锁住文件的操作步骤以及相关知识点,需要的朋友们参考下。
    2019-08-08
  • 关于c#中单例模式的一些问题

    关于c#中单例模式的一些问题

    这篇文章主要给大家介绍了关于c#中单例模式的一些问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • C#多线程系列之线程池

    C#多线程系列之线程池

    本文详细讲解了C#多线程中的线程池,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02

最新评论