aspose.cell 合并内容一样的单元格
/// <summary> /// 数据合并 /// </summary> /// <param name="mySheet"></param> /// <param name="columnIndex">合并的列下标</param> /// <param name="dataIndex">从哪一行开始</param> /// <param name="col"></param> private static void MergeCell_Second(Worksheet mySheet, int columnIndex,int dataIndex, string col) { Dictionary<string, Tuple<int, int, int, int>> tp = new Dictionary<string, Tuple<int, int, int, int>>(); string val = val = mySheet.Cells[dataIndex, columnIndex].Value.ToString().Trim();//数据行 int rowNum = mySheet.Cells.MaxDataRow;//最大行数 int mergeRow = 0; int startIndex = dataIndex; List<string> k = new List<string>(); bool isall = true; k.Add(val); for (int i= dataIndex; i< rowNum; i++) { val = mySheet.Cells[i, columnIndex].Value.ToString().Trim(); if (k.Contains(val)) { mergeRow++; k.Add(val); } else { isall = false; tp.Add(k[0], new Tuple<int, int, int, int>(startIndex, 0, mergeRow, 1)); k.Clear(); k.Add(val); mergeRow = 1; startIndex = i; } } if (isall) { tp.Add(k[0], new Tuple<int, int, int, int>(dataIndex, 0, rowNum, 1)); } if (!tp.ContainsKey(k[0])) { tp.Add(k[0], new Tuple<int, int, int, int>(startIndex, 0, mergeRow, 1)); } foreach(var item in tp) { mySheet.Cells.Merge(item.Value.Item1, columnIndex, item.Value.Item3, 1); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
2018-09-30 avalon SVG 画流程图