这篇文章介绍了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#实现DataTable数据行列转换
猜你喜欢
- Oracle中for循环的使用方法 2023-07-04
- .NET CORE DI 依赖注入 2023-09-27
- Unity Shader实现模糊效果 2023-04-27
- WPF使用DrawingContext实现绘制刻度条 2023-07-04
- user32.dll 函数说明小结 2022-12-26
- 如何使用C# 捕获进程输出 2023-03-10
- c# 模拟线性回归的示例 2023-03-14
- C# 使用Aspose.Cells 导出Excel的步骤及问题记录 2023-05-16
- 在C# 8中如何使用默认接口方法详解 2023-03-29
- Unity3D实现渐变颜色效果 2023-01-16