效果图如下: 代码如下: //检查参数 for(int col=0;col<columnCount;col++) //最后一行不用比较 range = (Excel.Range)workSheet.Cells[row + 1 + beginRowIndex,n + beginColumnIndex]; } if(row == rowCount – 2)
/**//// <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 ;
{
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)range.MergeArea.get_Item(1,1);
nextName = nextName + range.Text.ToString();
if(prvName == nextName)
{
mergeCount++;
{
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;
}
}
}
}
}
在excel中将连续多列相同数据项合并_c#应用
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 在excel中将连续多列相同数据项合并_c#应用
相关推荐
-      利用c#远程存取access数据库_c#应用
-      c# 3.0新特性系列:隐含类型var_c#教程
-      c#动态生成树型结构的web程序设计_c#应用
-      论c#变得越来越臃肿是不可避免的_c#应用
-      用c#监控并显示cpu状态信息_c#应用
-      c#中实现vb中的createobject方法_c#应用
-      photoshop给花瓶打造彩绘效果_photoshop教程
-      使用c#创建sql server的存储过程_c#应用