欢迎光临
我们一直在努力

在excel中将连续多列相同数据项合并_c#应用

建站超值云服务器,限时71元/月

效果图如下:
在excel中将连续多列相同数据项合并_c#应用


代码如下:
/**//// <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)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 在excel中将连续多列相同数据项合并_c#应用
分享到: 更多 (0)