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 = 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)类型。
本文来自博客园,作者:码农阿亮,转载请注明原文链接:https://www.cnblogs.com/wml-it/p/14866500.html
技术的发展日新月异,随着时间推移,无法保证本博客所有内容的正确性。如有误导,请大家见谅,欢迎评论区指正!
开源库地址,欢迎点亮:
GitHub:https://github.com/ITMingliang
Gitee: https://gitee.com/mingliang_it
GitLab: https://gitlab.com/ITMingliang
建群声明: 本着技术在于分享,方便大家交流学习的初心,特此建立【编程内功修炼交流群】,为大家答疑解惑。热烈欢迎各位爱交流学习的程序员进群,也希望进群的大佬能不吝分享自己遇到的技术问题和学习心得!进群方式:扫码关注公众号,后台回复【进群】。