C#在Excel中将连续多列相同数据项合并

效果图如下:

 /**//// <summary>
/// 合并工作表中指定行数和列数数据相同的单元格
/// </summary>
/// <param name="sheetIndex">工作表索引</param>
/// <param name="beginRowIndex">开始行索引</param>
/// <param name="beginColumnIndex">开始列索引</param>
/// <param name="rowCount">要合并的行数</param>
/// <param name="columnCount">要合并的列数</param>
        public void MergeWorkSheet(int sheetIndex,int beginRowIndex,int beginColumnIndex,int rowCount,int columnCount)
{
//检查参数
            if ( columnCount < 1 || rowCount < 1)
return ;
for(int col=0;col<columnCount;col++)
{
int mark = 0;            //标记比较数据中第一条记录位置
                int mergeCount = 1;        //相同记录数,即要合并的行数
                string text = "";
for(int row=0;row<rowCount;row++)
{
string prvName = "";
string nextName = "";
//最后一行不用比较
                    if( row + 1 < rowCount)
{
for(int n=0;n<=col;n++)
{
range
= (Excel.Range)workSheet.Cells[row + beginRowIndex,n + beginColumnIndex];
range
= (Excel.Range)range.MergeArea.get_Item(1,1);
text
= range.Text.ToString();
prvName
= prvName + text;
range
= (Excel.Range)workSheet.Cells[row + 1 + beginRowIndex,n + beginColumnIndex];
range
= (Excel.Range)range.MergeArea.get_Item(1,1);
nextName
= nextName + range.Text.ToString();
}
if(prvName == nextName)
{
mergeCount
++;
if(row == rowCount - 2)
{
this.MergeCells(sheetIndex,beginRowIndex + mark,beginColumnIndex + col,beginRowIndex + mark + mergeCount - 1,beginColumnIndex + col,text);
}
}
else
{
this.MergeCells(sheetIndex,beginRowIndex + mark,beginColumnIndex + col,beginRowIndex + mark + mergeCount - 1,beginColumnIndex + col,text);
mergeCount
= 1;
mark
= row + 1;
}
}
}
}
}
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值