C#實現(xiàn)DataTable數(shù)據(jù)行列轉(zhuǎn)換
更新時間:2022年04月21日 09:42:03 作者:農(nóng)碼一生
這篇文章介紹了C#實現(xiàn)DataTable數(shù)據(jù)行列轉(zhuǎn)換的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
一、代碼
public static DataTable RevertRowToColumn(DataTable sourcedt)
{
DataTable dt = new DataTable();
//轉(zhuǎn)換后的第一列名,以后此列每行存放sourcedt對應(yīng)對應(yīng)的每列列名
dt.Columns.Add("COLUMN_NAME", typeof(string));
//第二行及以后,轉(zhuǎn)換后重命名的列名,列數(shù)等于sourcedt行數(shù)
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));//統(tǒng)一按照string類型進(jìn)行存放
}
//對sourcedt進(jìn)行轉(zhuǎn)換
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的列名賦值給轉(zhuǎn)換成行的第一列值
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;
}二、結(jié)果
轉(zhuǎn)置前:

轉(zhuǎn)置后:

注意:此轉(zhuǎn)換的每列列類型統(tǒng)一為:typeof(string)類型。
到此這篇關(guān)于C#實現(xiàn)DataTable數(shù)據(jù)行列轉(zhuǎn)換的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- C#把DataTable導(dǎo)出為Excel文件
- C#實現(xiàn)DataTable轉(zhuǎn)TXT、CSV文件
- C#對DataTable中的某列進(jìn)行分組
- C#獲取DataTable對象狀態(tài)DataRowState
- c#中DataTable轉(zhuǎn)List的2種方法示例
- C#中DataTable的創(chuàng)建與遍歷實現(xiàn)
- C#去除DataTable重復(fù)數(shù)據(jù)的三種方法
- C# DataTable數(shù)據(jù)遍歷優(yōu)化詳解
- C# Datatable的幾種用法小結(jié)
- C#中的DataTable查詢實戰(zhàn)教程
- C# DataTable與Model互轉(zhuǎn)的示例代碼
- C# DataTable常見用法匯總
相關(guān)文章
使用Http Head方法獲取文件長度的實現(xiàn)方法詳解
本篇文章是對使用Http Head方法獲取文件長度的實現(xiàn)方法進(jìn)行詳細(xì)的分析介紹,需要的朋友參考下2013-05-05

