将指定索引列的数据相同的行合并

这段代码展示了如何在Excel工作表中合并指定列索引上具有相同数据的连续行。通过遍历指定行范围,比较相邻行的值,当找到相同值时进行行合并。提供了针对所有工作表和特定工作表的操作方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/// <summary>
  /// 将指定索引列的数据相同的行合并,对每个WorkSheet操作
  /// </summary>
  /// <param name="columnIndex">列索引</param>
  /// <param name="beginRowIndex">开始行索引</param>
  /// <param name="endRowIndex">结束行索引</param>
  public void MergeRows(int columnIndex,int beginRowIndex,int endRowIndex)
  {
   if(endRowIndex - beginRowIndex < 1)
    return;

   for(int i=1;i<=this.WorkSheetCount;i++)
   {
    int beginIndex = beginRowIndex;
    int count = 0;
    string text1;
    string text2;
    workSheet = (Excel.Worksheet)workBook.Worksheets.get_Item(i);

    for(int j=beginRowIndex;j<=endRowIndex;j++)
    {
     range = (Excel.Range)workSheet.Cells[j,columnIndex];
     text1 = range.Text.ToString();

     range = (Excel.Range)workSheet.Cells[j+1,columnIndex];
     text2 = range.Text.ToString();

     if(text1 == text2)
     {
      ++count;
     }
     else
        
      if(count > 0)
      {
       this.MergeCells(workSheet,beginIndex,columnIndex,beginIndex+count,columnIndex,text1);
      }

      beginIndex = j + 1;  //设置开始合并行索引
      count = 0;  //计数器清0
     }

    }

   }
  }


  /// <summary>
  /// 将指定索引列的数据相同的行合并,对指定WorkSheet操作
  /// </summary>
  /// <param name="sheetIndex">WorkSheet索引</param>
  /// <param name="columnIndex">列索引</param>
  /// <param name="beginRowIndex">开始行索引</param>
  /// <param name="endRowIndex">结束行索引</param>
  public void MergeRows(int sheetIndex,int columnIndex,int beginRowIndex,int endRowIndex)
  {
   if(sheetIndex > this.WorkSheetCount)
   {
    this.KillExcelProcess();
    throw new Exception("索引超出范围,WorkSheet索引不能大于WorkSheet数量!");
   }

   if(endRowIndex - beginRowIndex < 1)
    return;

   int beginIndex = beginRowIndex;
   int count = 0;
   string text1;
   string text2;
   workSheet = (Excel.Worksheet)workBook.Worksheets.get_Item(sheetIndex);

   for(int j=beginRowIndex;j<=endRowIndex;j++)
   {
    range = (Excel.Range)workSheet.Cells[j,columnIndex];
    text1 = range.Text.ToString();

    range = (Excel.Range)workSheet.Cells[j+1,columnIndex];
    text2 = range.Text.ToString();

    if(text1 == text2)
    {
     ++count;
    }
    else
       
     if(count > 0)
     {
      this.MergeCells(workSheet,beginIndex,columnIndex,beginIndex+count,columnIndex,text1);
     }

     beginIndex = j + 1;  //设置开始合并行索引
     count = 0;  //计数器清0
    }

   }

  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值