zoukankan      html  css  js  c++  java
  • 将两个DataTable合并成一个DataTable

    //1.两个结构一样的DT合并
    DataTable DataTable1 = new DataTable();
    DataTable DataTable2 = new DataTable();
    DataTable newDataTable = DataTable1.Clone();

    object[] obj = new object[newDataTable.Columns.Count];
    for (int i = 0; i < DataTable1.Rows.Count; i++)
    {
        DataTable1.Rows[i].ItemArray.CopyTo(obj,0);
        newDataTable.Rows.Add(obj);
    }

    for (int i = 0; i < DataTable2.Rows.Count; i++)
    {
        DataTable2.Rows[i].ItemArray.CopyTo(obj,0);
        newDataTable.Rows.Add(obj);
    }


    //2.两个结构不同的DT合并
    /// <summary>
      /// 将两个列不同的DataTable合并成一个新的DataTable
      /// </summary>
      /// <param name="dt1">表1</param>
      /// <param name="dt2">表2</param>
      /// <param name="DTName">合并后新的表名</param>
      /// <returns></returns>
      private DataTable UniteDataTable( DataTable dt1 ,DataTable dt2 ,string DTName)
      { 
       DataTable dt3 = dt1.Clone();
       for( int i = 0 ;i < dt2.Columns.Count ;i ++ )
       {
        dt3.Columns.Add( dt2.Columns[i].ColumnName ) ;
       }
       object[] obj = new object[dt3.Columns.Count];
       for (int i = 0; i < dt1.Rows.Count; i++)
       {
        dt1.Rows[i].ItemArray.CopyTo(obj,0);
        dt3.Rows.Add(obj);
       }
       if( dt1.Rows.Count >= dt2.Rows.Count )
       {
        for( int i = 0 ;i < dt2.Rows.Count ;i++ )
        {
         for( int j = 0 ;j < dt2.Columns.Count ;j ++ )
         {
          dt3.Rows[i][j+dt1.Columns.Count] = dt2.Rows[i][j].ToString() ;
         }
        }
       }
       else
       {
        DataRow dr3 ;
        for( int i = 0 ;i < dt2.Rows.Count - dt1.Rows.Count ;i ++ )
        {
         dr3 = dt3.NewRow() ;
         dt3.Rows.Add( dr3 ) ;
        }
        for( int i = 0 ;i < dt2.Rows.Count ;i++ )
        {
         for( int j = 0 ;j < dt2.Columns.Count ;j ++ )
         {
          dt3.Rows[i][j+dt1.Columns.Count] = dt2.Rows[i][j].ToString() ;
         }
        }
       }
       dt3.TableName = DTName ; //设置DT的名字
       return dt3 ;
      }

  • 相关阅读:
    Java正则表达式匹配例子
    python实现的json数据以HTTP GET,POST,PUT,DELETE方式页面请求
    pure-Python PDF library
    搭建nginx反向代理用做内网域名转发
    ASCII、Unicode、UTF-8 字符串和编码
    pdftk
    SQL中distinct 和 row_number() over() 的区别及用法
    使用Python进行AES加密和解密
    python中zip()函数的用法
    查找只出现一次的字符和位置
  • 原文地址:https://www.cnblogs.com/Spring/p/858707.html
Copyright © 2011-2022 走看看