在GRIDVIEW中合并单元格

  1.  ///   合并GridView列中相同的行   
  2.     ///      
  3.     ///   GridView对象   
  4.     ///   需要合并的列   
  5.     public static void GroupRows(GridView GridView1, int cellNum)
  6.     {
  7.         int i = 0, rowSpanNum = 1;
  8.         while (i < GridView1.Rows.Count - 1)
  9.         {
  10.             GridViewRow gvr = GridView1.Rows[i];
  11.             for (++i; i < GridView1.Rows.Count; i++)
  12.             {
  13.                 GridViewRow gvrNext = GridView1.Rows[i];
  14.                 if (gvr.Cells[cellNum].Text == gvrNext.Cells[cellNum].Text)
  15.                 {
  16.                     gvrNext.Cells[cellNum].Visible = false;
  17.                     rowSpanNum++;
  18.                 }
  19.                 else
  20.                 {
  21.                     gvr.Cells[cellNum].RowSpan = rowSpanNum;
  22.                     rowSpanNum = 1;
  23.                     break;
  24.                 } 
  25.                 if (i == GridView1.Rows.Count - 1)
  26.                 {
  27.                     gvr.Cells[cellNum].RowSpan = rowSpanNum;
  28.                 }
  29.             }
  30.         }
  31.     } 
  32.     ///      
  33.     ///   根据条件列合并GridView列中相同的行   
  34.     ///      
  35.     ///   GridView对象   
  36.     ///   需要合并的列
  37.     ///   ///   条件列(根据某条件列还合并)
  38.     public static void GroupRows(GridView GridView1, int cellNum, int cellNum2)
  39.     {
  40.         int i = 0, rowSpanNum = 1;
  41.         while (i < GridView1.Rows.Count - 1)
  42.         {
  43.             GridViewRow gvr = GridView1.Rows[i];
  44.             for (++i; i < GridView1.Rows.Count; i++)
  45.             {
  46.                 GridViewRow gvrNext = GridView1.Rows[i];
  47.                 if (gvr.Cells[cellNum].Text + gvr.Cells[cellNum2].Text == gvrNext.Cells[cellNum].Text + gvrNext.Cells[cellNum2].Text)
  48.                 {
  49.                     gvrNext.Cells[cellNum].Visible = false;
  50.                     rowSpanNum++;
  51.                 }
  52.                 else
  53.                 {
  54.                     gvr.Cells[cellNum].RowSpan = rowSpanNum;
  55.                     rowSpanNum = 1;
  56.                     break;
  57.                 } 
  58.                 if (i == GridView1.Rows.Count - 1)
  59.                 {
  60.                     gvr.Cells[cellNum].RowSpan = rowSpanNum;
  61.                 }
  62.             }
  63.         }
  64.     } 
  65.   
  66. 第二个方法只是在第一个方法的修改了一点点, 在判断单元格的时候,加上了一个条件列:
  67. if (gvr.Cells[cellNum].Text + gvr.Cells[cellNum2].Text == gvrNext.Cells[cellNum].Text + gvrNext.Cells[cellNum2].Text)。当然,第二个方法还可以扩展,根据多个列的条件来合并。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值