C#实现DataTable行列转置

Posted 農碼一生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#实现DataTable行列转置相关的知识,希望对你有一定的参考价值。

C#实现DataTable行列转置

一、代码

      public static DataTable RevertRowToColumn(DataTable sourcedt)
        {
            DataTable dt = new DataTable();
            //转换后的第一列名,以后此列每行存放sourcedt对应对应的每列列名
            dt.Columns.Add("COLUMN_NAME", typeof(string));
            //第二行及以后,转换后重命名的列名,列数等于sourcedt行数
            string[] aa = { "VLAUE_1", "VLAUE_2", "VLAUE_3", "VLAUE_4", "VLAUE_5", "VLAUE_6", "VLAUE_7", "VLAUE_8", "VLAUE_9", "VLAUE_10" };
            //添加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行列转置的主要内容,如果未能解决你的问题,请参考以下文章

Excel-怎样实现行列转置

简化实现动态行列转置的SQL

对一个方阵转置,就是把原来的行号变列号,原来的列号变行号

C#将查询返回的数据(一行多列)怎么转换成一列多行dataTable?

C语言试题二十七之请编写程序,实现矩阵(3行3列)的转置(即行列互换)。

C语言试题二十七之请编写程序,实现矩阵(3行3列)的转置(即行列互换)。