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" ...
随机推荐
- for-in循环(for-in Loops)
for-in循环应该用在非数组对象的遍历上,使用for-in进行循环也被称为“枚举”. 从技术上将,你可以使用for-in循环数组(因为JavaScript中数组也是对象),但这是不推荐的.因为如果数 ...
- 搭建LDAP服务器
1. 使用SSH 登陆服务器. 2. 更新有效的包. sudo apt-get update 3. 安装LDAP和一些其它LDAP相关的工具. sudo apt-get install slapd l ...
- 001 jquery对象与dom对象的转换
1.jQuery对象介绍 2.jQuery对象转换为Dom对象 3.Dom转换为Jquery对象 4.将jquery转换为Dom程序 <!DOCTYPE html> <html> ...
- Python学习笔记之爬取网页保存到本地文件
爬虫的操作步骤: 爬虫三步走 爬虫第一步:使用requests获得数据: (request库需要提前安装,通过pip方式,参考之前的博文) 1.导入requests 2.使用requests.get ...
- 20172301 《Java软件结构与数据结构》实验二报告
20172301 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...
- 深入分析Spring Boot2,解决 java.lang.ArrayStoreException异常
将某个项目从Spring Boot1升级Spring Boot2之后出现如下报错,查了很多不同的解决方法都没有解决: Spring boot2项目启动时遇到了异常: java.lang.ArraySt ...
- collectionFramwork-1
1. Set.List和Map可以看做集合的三大类. List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根据元素的索引来访问. Set集合是无序集合,集合中的元素不可以重复,访问集合中 ...
- 系统的Drawable(二)-Selector
系统的Drawable(二)-Selector Selector漫谈 Selector是定义 StateListDrawable 的标签,该Drawable代表着一个Drawable的集合,每一个Dr ...
- 网页图表Highcharts实践教程之图表区
网页图表Highcharts实践教程之图表区 网页图表Highcharts图表区 图表区是图表的基本区域.所有的数据和图形都是绘制在图表区中.从图形绘制范围来分,图表区域分为外层图表区和绘图区.本章将 ...
- 运行程序,解读this指向---case4
var param = 'window'; var obj1 = { param: 'obj1', fn1: function () { console.log(this.param); }, fn2 ...