C# NPOI如何合并Excel中的单元格-完整版
分类:计算机 | C# | C#操作Office | NPOI 951
更新: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;
}
}
猿导航
阅读排行榜
- 1three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目7973
- 2vue和el-table使用经验-如何刷新表格数据7664
- 3uni-app使用经验—vue页面和html页面如何互相调用接口并传参3709
- 4Spring学习经验—@ResponseBody注解的使用说明2245
- 5nuxt.js项目中如何添加和使用全局变量2224
- 6如何用批处理命令(bat脚本)启动和停止windows服务2170
- 7Intellij IDEA下的版本控制VCS的启用与关闭2086
- 8Druid异常解决经验—java.sql.SQLException url not set2059
- 9nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数2030
- 10解决SpringBoot使用maven下载不了jar包的问题1992
- 11mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)1927
- 12在Nuxt.js项目的head中引用外部js文件1807
- 13linux如何成功地离线安装docker1794
- 14Nuxt.js项目实现路由鉴权和用户登录1782
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一1776