POI Excel表格合并,边框设置
- RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
- Row row=sheet.createRow((short)0);
- ImageUtil.createCell("排序", 0, sctext, row);
- CellRangeAddress CellRangeAddress1 = new CellRangeAddress(0,2,0,0);
- sheet.addMergedRegion(CellRangeAddress1);
- RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
- ImageUtil.createCell("项目名称", 1, sctext, row);
- CellRangeAddress CellRangeAddress2 = new CellRangeAddress(0,2,1,1);
- sheet.addMergedRegion(CellRangeAddress2);
- ImageUtil.createCell("姓名", 2, sctext, row);
- CellRangeAddress CellRangeAddress3 = new CellRangeAddress(0,2,2,2);
- sheet.addMergedRegion(CellRangeAddress3);
- ImageUtil.createCell("各指标完成情况总数据", 3, sctext, row);
- CellRangeAddress CellRangeAddress4 = new CellRangeAddress(0,0,3,8);
- sheet.addMergedRegion(new CellRangeAddress(0,0,3,8));
- ImageUtil.createCell("各指标完成率", 9, sctext, row);
- CellRangeAddress CellRangeAddress5 = new CellRangeAddress(0,0,9,14);
- sheet.addMergedRegion(CellRangeAddress5);
- Row row2=sheet.createRow((short)1);
- ImageUtil.createCell("覆盖面", 3, sctext, row2);
- CellRangeAddress CellRangeAddress6 = new CellRangeAddress(1,1,3,4);
- sheet.addMergedRegion(CellRangeAddress6);
- ImageUtil.createCell("频次", 5, sctext, row2);
- CellRangeAddress CellRangeAddress7 = new CellRangeAddress(1,1,5,6);
- sheet.addMergedRegion(CellRangeAddress7);
结果如下图:

最后是顺序问题导致的.其原因是因为在编辑单元格的时候,后者覆盖了前者的style.
解决办法:
封装了一个方法:
- public void setBorder(CellRangeAddress cellRangeAddress, Sheet sheet,
- Workbook wb) throws Exception {
- RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
- RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
- }
然后将调用该方法的步骤放到最后,记得是最后,就是全部单元格合并之后,否则会覆盖的,如下:
- super.setBorder(CellRangeAddress1, sheet, book);
- super.setBorder(CellRangeAddress2, sheet, book);
- super.setBorder(CellRangeAddress3, sheet, book);
- super.setBorder(CellRangeAddress4, sheet, book);
- super.setBorder(CellRangeAddress5, sheet, book);
- super.setBorder(CellRangeAddress6, sheet, book);
- super.setBorder(CellRangeAddress7, sheet, book);
- super.setBorder(CellRangeAddress8, sheet, book);
- super.setBorder(CellRangeAddress9, sheet, book);
- super.setBorder(CellRangeAddress10, sheet, book);
- super.setBorder(CellRangeAddress11, sheet, book);
- super.setBorder(CellRangeAddress12, sheet, book);
- super.setBorder(CellRangeAddress13, sheet, book);
- super.setBorder(CellRangeAddress14, sheet, book);
- super.setBorder(CellRangeAddress15, sheet, book);
- super.setBorder(CellRangeAddress16, sheet, book);
POI Excel表格合并,边框设置的更多相关文章
- Python将多个excel表格合并为一个表格
Python将多个excel表格合并为一个表格 生活中经常会碰到多个excel表格汇总成一个表格的情况,比如你发放了一份表格让班级所有同学填写,而你负责将大家的结果合并成一个.诸如此类的问题有很多.除 ...
- asp.net数据导出到excel表格,并设置表格样式
1.首先在项目中添加引用
- CSS开发技巧(二):表格合并边框后的单元格宽度计算
前言: 分离边框模型和合并边框模型是表格的两种模型,它通过以下属性确定: border-collapse:separate(默认值) | collapse | inherit 当采用分离边框模型时,表 ...
- phpStudy6——php导出可以设置样式的excel表格
前言: 一般的后台管理页面肯定少不了excel表格导出的功劳,尤其是那些电商平台的订单导入导出,用户列表的导入导出等,那么本文就介绍php是如何导出excel表格的. php导出excel方法有很多, ...
- java中使用jxl导出Excel表格详细通用步骤
该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入s ...
- 复杂的POI导出Excel表格(多行表头、合并单元格)
poi导出excel有两种方式: 第一种:从无到有的创建整个excel,通过HSSFWorkbook,HSSFSheet HSSFCell, 等对象一步一步的创建出工作簿,sheet,和单元格,并添加 ...
- NPOI_winfrom导出Excel表格(一)(合并单元格、规定范围加外边框、存储路径弹框选择)
1.导出 private void btn_print_Click(object sender, EventArgs e) { DataTable dtNew = new DataTable(); d ...
- 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法
本篇文章小编为大家介绍,用NPOI创建Excel.合并单元格.设置单元格样式.边框的方法.需要的朋友参考下 今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Ex ...
- Python快速设置Excel表格边框
import xlwings as xw #打开存好的excel app = xw.App() #设置应用 wb = xw.Book("E:/Data/小蜜蜂超市销售报表.xlsx" ...
随机推荐
- 【AtCoder】AGC022
A - Diverse Word 不到26位就加上一个最小的 到26位了就搜一下,最多回溯就一次,所以复杂度不大 #include <iostream> #include <cstd ...
- 034 Spark Sql的入门介绍
一:进程介绍 1.use sql 2.shark 3.spark sql 4.终止shark 5.进程线 二:spark sql细节介绍 1.hive 与sparkSql比较(以后具体学习) 2.使用 ...
- 如何启用内置的Win10 OpenSSH客户端(转)
如何启用内置的Win10 OpenSSH客户端 关注Windows10,锁定Win10之家(http://www.ghost580.com/windows10/) 如何启用内置的Win10 OpenS ...
- odoo视图继承
odoo视图继承 简介继承 在odoo里可以通过继承的方式来改写已经存在的view 对比view的定义视图定义中写法多了inherit_id inherit_id指向要改写的view <fiel ...
- UOJ.52.[UR #4]元旦激光炮(交互 思路)
题目链接 \(Description\) 交互库中有三个排好序的,长度分别为\(n_a,n_b,n_c\)的数组\(a,b,c\).你需要求出所有元素中第\(k\)小的数.你可以调用至多\(100\) ...
- hdu 5203 && BC Round #37 1002
代码参考自:xyz111 题意: 众所周知,萌萌哒六花不擅长数学,所以勇太给了她一些数学问题做练习,其中有一道是这样的:勇太有一根长度为n的木棍,这个木棍是由n个长度为1的小木棍拼接而成,当然由于时间 ...
- android.intent.category.DEFAULT
我们需要什么时候加android.intent.category.DEFAULT呢? 1.要弄清楚这个问题,首先需要弄明白什么是implicit(隐式) intent什么是explicit(显示) i ...
- 【BZOJ-2595】游览计划 斯坦纳树
2595: [Wc2008]游览计划 Time Limit: 10 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 1518 Solved: 7 ...
- DOM操作——JavaScript怎样添加、移除、移动、复制、创建和查找节点
(1). 创建新节点 createDocumentFragment() // 创建一个DOM片段 createElement() // 创建一个具体的元素 createTextNode() // 创建 ...
- hdu 5773 The All-purpose Zero 线段树 dp
The All-purpose Zero 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5773 Description ?? gets an seq ...