C# NPOI如何合并Excel中的单元格-完整版
分类:计算机 | C# | C#操作Office | NPOI 1793
更新:2020-05-14 22:42:39编辑
/// <summary>
/// 合并excel单元格
/// </summary>
/// <param name="filePath">excel文件路径</param>
/// <param name="startRow">从第几行开始合并</param>
/// <param name="endRow">到第几行结束合并</param>
/// <param name="startCol">从第几列开始合并</param>
/// <param name="endCol">到第几列结束合并</param>
/// <returns></returns>
public static bool MergeCell(string filePath, int startRow,int endRow,int startCol,int endCol)
{
if (!File.Exists(filePath)) return false;
FileStream fs = null;
try
{
fs = new FileStream(filePath, FileMode.Open, FileAccess.Read); //打开excel文件流
IWorkbook workbook = WorkbookFactory.Create(fs); //根据excel文件流创建NPOI的excel工作簿
ISheet sheet = workbook.GetSheetAt(0); //获取excel第一个sheet
CellRangeAddress region = new CellRangeAddress(startRow, endRow, startCol, endCol); //设置合并单元格范围
sheet.AddMergedRegion(region); //合并单元格
fs.Close();
//将修改后的excel工作薄先写入内存中,然后保存到本地流
MemoryStream stream = new MemoryStream();
workbook.Write(stream);
var buf = stream.ToArray();
fs = new FileStream(filePath, FileMode.Create, FileAccess.Write);
fs.Write(buf, 0, buf.Length);
fs.Flush();
fs.Close();
return true;
}
catch (Exception ex)
{
return false;
}
}
猿导航
阅读排行榜
- 1vue和el-table使用经验-如何刷新表格数据10886
- 2three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目9449
- 3Microsoft Visual C++ Redistributable是什么,有什么作用?7182
- 4mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)5760
- 5uni-app使用经验—vue页面和html页面如何互相调用接口并传参5438
- 6Spring学习经验—@ResponseBody注解的使用说明4845
- 7Intellij IDEA下的版本控制VCS的启用与关闭4788
- 8Druid异常解决经验—java.sql.SQLException url not set4466
- 9如何用批处理命令(bat脚本)启动和停止windows服务4231
- 10nuxt.js项目中如何添加和使用全局变量4098
- 11解决SpringBoot使用maven下载不了jar包的问题3452
- 12linux中解压tar.gz文件报错“gzip: stdin: invalid compressed data--format violated”3344
- 13nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数3206
- 14在Nuxt.js项目的head中引用外部js文件3043
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一3020