C#中DataTable实现行列转换的方法

 更新时间:2015年04月27日 14:33:59   作者:lele  
这篇文章主要介绍了C#中DataTable实现行列转换的方法,实例分析了C#操作DataTable的相关技巧,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了C#中DataTable实现行列转换的方法。分享给大家供大家参考。具体实现方法如下:

protected void Page_Load(object sender, EventArgs e)
{
  if (!IsPostBack)
  {
   DataTable tt = GetCrossTable(CreateDT());
   GridView1.DataSource = tt;
   GridView1.DataBind();
  }
}
//创建DataTable
protected DataTable CreateDT()
{
  DataTable tblDatas = new DataTable("Datas");
  //数据列
  tblDatas.Columns.Add("姓名", Type.GetType("System.String"));
  tblDatas.Columns.Add("科目", Type.GetType("System.String"));
  tblDatas.Columns.Add("分数", Type.GetType("System.Int32"));
  tblDatas.Rows.Add(new object[] { "张三", "语文", 89 });
  tblDatas.Rows.Add(new object[] { "张三", "数学", 90 });
  tblDatas.Rows.Add(new object[] { "张三", "英语", 79 });
  tblDatas.Rows.Add(new object[] { "张三", "地理", 70 });
  tblDatas.Rows.Add(new object[] { "张三", "生物", 95 });
  tblDatas.Rows.Add(new object[] { "李四", "语文", 87 });
  tblDatas.Rows.Add(new object[] { "李四", "英语", 86 });
  tblDatas.Rows.Add(new object[] { "李四", "地理", 82 });
  tblDatas.Rows.Add(new object[] { "王五", "语文", 81 });
  tblDatas.Rows.Add(new object[] { "王五", "数学", 70 });
  tblDatas.Rows.Add(new object[] { "王五", "英语", 88 });
  tblDatas.Rows.Add(new object[] { "王五", "生物", 96 });
  return tblDatas;
}
/// <summary>
/// 将DataTable的第二列的值转化为列
//(即将原来的行表,转化成交叉表,没有对应值则默认"0")
/// </summary>
/// <param name="dt">必须三列,第三列为值</param>
/// <returns></returns>
public static DataTable GetCrossTable(DataTable dt)
{
  if (dt == null || dt.Columns.Count != 3 || dt.Rows.Count == 0)
  {
   return dt;
  }
  else
  {
   DataTable result = new DataTable();
   result.Columns.Add(dt.Columns[0].ColumnName);
   DataTable dtColumns = dt.DefaultView.ToTable("dtColumns", true, dt.Columns[1].ColumnName);
   for (int i = 0; i < dtColumns.Rows.Count; i++)
   {
    string colName;
    if (dtColumns.Rows[1][0] is DateTime)
    {
     colName = Convert.ToDateTime(dtColumns.Rows[i][0]).ToString();
    }
    else
    {
     colName = dtColumns.Rows[i][0].ToString();
    }
    result.Columns.Add(colName);
    result.Columns[i + 1].DefaultValue = "0";
   }
   DataRow drNew = result.NewRow();
   drNew[0] = dt.Rows[0][0];
   string rowName = drNew[0].ToString();
   foreach (DataRow dr in dt.Rows)
   {
    string colName = dr[1].ToString();
    double dValue = Convert.ToDouble(dr[2]);
    if (dr[0].ToString().Equals(rowName, StringComparison.CurrentCultureIgnoreCase))
    {
     drNew[colName] = dValue.ToString();
    }
    else
    {
     result.Rows.Add(drNew);
     drNew = result.NewRow();
     drNew[0] = dr[0];
     rowName = drNew[0].ToString();
     drNew[colName] = dValue.ToString();
    }
   }
   result.Rows.Add(drNew);
   return result;
  }
}

希望本文所述对大家的C#程序设计有所帮助。

相关文章

  • Unity实现音频播放管理器

    Unity实现音频播放管理器

    这篇文章主要为大家详细介绍了Unity实现音频播放管理器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • C#播放音频文件的详细步骤

    C#播放音频文件的详细步骤

    这篇文章主要介绍了C#播放音频文件的详细步骤,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • C#应用程序与数据库的集成几种方法

    C#应用程序与数据库的集成几种方法

    应用程序集成数据库是许多软件项目的关键方面,无论构建的是Web应用程序、桌面应用程序还是移动应用程序,高效无缝地与数据库集成,对于存储、检索和操作数据都至关重要,本文将介绍数据库与C#应用程序集成的几种方法与使用注意事项,需要的朋友可以参考下
    2024-06-06
  • C#多线程之线程同步WaitHandle

    C#多线程之线程同步WaitHandle

    这篇文章介绍了C#多线程之线程同步WaitHandle的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C#实现将HTML网页或HTML字符串转换为PDF

    C#实现将HTML网页或HTML字符串转换为PDF

    将HTML转换为PDF可实现格式保留、可靠打印、文档归档等多种用途,满足不同领域和情境下的需求,所以本文就来介绍一下如何使用C#实现将HTML网页或HTML字符串转换为PDF,有需要的可以参考下
    2024-01-01
  • C#简单读取主机上所有进程的方法

    C#简单读取主机上所有进程的方法

    这篇文章主要介绍了C#简单读取主机上所有进程的方法,涉及C#进程的遍历读取操作相关实现技巧,需要的朋友可以参考下
    2016-08-08
  • C#使用this关键字实现串联构造函数调用方法

    C#使用this关键字实现串联构造函数调用方法

    这篇文章主要介绍了C#使用this关键字实现串联构造函数调用方法,实例分析了使用this关键字串联构造函数的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • Unity幸运转盘实战项目

    Unity幸运转盘实战项目

    这篇文章主要为大家详细介绍了Unity幸运转盘实战项目,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • C#使用泛型方法设计实现单向链表详解

    C#使用泛型方法设计实现单向链表详解

    这篇文章主要为大家详细介绍了C#如何使用泛型方法设计实现一个单向链表,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-02-02
  • 对c#中托的理解

    对c#中托的理解

    本篇文章,小编将为大家介绍关于对c#中托的理解,有需要的朋友可以参考一下
    2013-04-04

最新评论