1. RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
  2. RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
  3. RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
  4. RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
上面是加边框的核心代码,为单元格的上,下左,右四边加边框!我测试在单个合并单元格的时候,是没有什么问题的!但是当我用下面代码的时候会出现有的边框没有

  1. Row row=sheet.createRow((short)0);
  2. ImageUtil.createCell("排序", 0, sctext, row);
  3. CellRangeAddress CellRangeAddress1 = new CellRangeAddress(0,2,0,0);
  4. sheet.addMergedRegion(CellRangeAddress1);
  5. RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
  6. RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
  7. RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
  8. RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
  9. ImageUtil.createCell("项目名称", 1, sctext, row);
  10. CellRangeAddress CellRangeAddress2 = new CellRangeAddress(0,2,1,1);
  11. sheet.addMergedRegion(CellRangeAddress2);
  12. ImageUtil.createCell("姓名", 2, sctext, row);
  13. CellRangeAddress CellRangeAddress3 = new CellRangeAddress(0,2,2,2);
  14. sheet.addMergedRegion(CellRangeAddress3);
  15. ImageUtil.createCell("各指标完成情况总数据", 3, sctext, row);
  16. CellRangeAddress CellRangeAddress4 = new CellRangeAddress(0,0,3,8);
  17. sheet.addMergedRegion(new CellRangeAddress(0,0,3,8));
  18. ImageUtil.createCell("各指标完成率", 9, sctext, row);
  19. CellRangeAddress CellRangeAddress5 = new CellRangeAddress(0,0,9,14);
  20. sheet.addMergedRegion(CellRangeAddress5);
  21. Row row2=sheet.createRow((short)1);
  22. ImageUtil.createCell("覆盖面", 3, sctext, row2);
  23. CellRangeAddress CellRangeAddress6 = new CellRangeAddress(1,1,3,4);
  24. sheet.addMergedRegion(CellRangeAddress6);
  25. ImageUtil.createCell("频次", 5, sctext, row2);
  26. CellRangeAddress CellRangeAddress7 = new CellRangeAddress(1,1,5,6);
  27. sheet.addMergedRegion(CellRangeAddress7);

结果如下图:

最后是顺序问题导致的.其原因是因为在编辑单元格的时候,后者覆盖了前者的style.

解决办法:

封装了一个方法:

  1. public void setBorder(CellRangeAddress cellRangeAddress, Sheet sheet,
  2. Workbook wb) throws Exception {
  3. RegionUtil.setBorderLeft(1, cellRangeAddress, sheet, wb);
  4. RegionUtil.setBorderBottom(1, cellRangeAddress, sheet, wb);
  5. RegionUtil.setBorderRight(1, cellRangeAddress, sheet, wb);
  6. RegionUtil.setBorderTop(1, cellRangeAddress, sheet, wb);
  7. }

然后将调用该方法的步骤放到最后,记得是最后,就是全部单元格合并之后,否则会覆盖的,如下:

  1. super.setBorder(CellRangeAddress1, sheet, book);
  2. super.setBorder(CellRangeAddress2, sheet, book);
  3. super.setBorder(CellRangeAddress3, sheet, book);
  4. super.setBorder(CellRangeAddress4, sheet, book);
  5. super.setBorder(CellRangeAddress5, sheet, book);
  6. super.setBorder(CellRangeAddress6, sheet, book);
  7. super.setBorder(CellRangeAddress7, sheet, book);
  8. super.setBorder(CellRangeAddress8, sheet, book);
  9. super.setBorder(CellRangeAddress9, sheet, book);
  10. super.setBorder(CellRangeAddress10, sheet, book);
  11. super.setBorder(CellRangeAddress11, sheet, book);
  12. super.setBorder(CellRangeAddress12, sheet, book);
  13. super.setBorder(CellRangeAddress13, sheet, book);
  14. super.setBorder(CellRangeAddress14, sheet, book);
  15. super.setBorder(CellRangeAddress15, sheet, book);
  16. super.setBorder(CellRangeAddress16, sheet, book);

 

POI Excel表格合并,边框设置的更多相关文章

  1. Python将多个excel表格合并为一个表格

    Python将多个excel表格合并为一个表格 生活中经常会碰到多个excel表格汇总成一个表格的情况,比如你发放了一份表格让班级所有同学填写,而你负责将大家的结果合并成一个.诸如此类的问题有很多.除 ...

  2. asp.net数据导出到excel表格,并设置表格样式

    1.首先在项目中添加引用

  3. CSS开发技巧(二):表格合并边框后的单元格宽度计算

    前言: 分离边框模型和合并边框模型是表格的两种模型,它通过以下属性确定: border-collapse:separate(默认值) | collapse | inherit 当采用分离边框模型时,表 ...

  4. phpStudy6——php导出可以设置样式的excel表格

    前言: 一般的后台管理页面肯定少不了excel表格导出的功劳,尤其是那些电商平台的订单导入导出,用户列表的导入导出等,那么本文就介绍php是如何导出excel表格的. php导出excel方法有很多, ...

  5. java中使用jxl导出Excel表格详细通用步骤

    该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入s ...

  6. 复杂的POI导出Excel表格(多行表头、合并单元格)

    poi导出excel有两种方式: 第一种:从无到有的创建整个excel,通过HSSFWorkbook,HSSFSheet HSSFCell, 等对象一步一步的创建出工作簿,sheet,和单元格,并添加 ...

  7. NPOI_winfrom导出Excel表格(一)(合并单元格、规定范围加外边框、存储路径弹框选择)

    1.导出 private void btn_print_Click(object sender, EventArgs e) { DataTable dtNew = new DataTable(); d ...

  8. 用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

    本篇文章小编为大家介绍,用NPOI创建Excel.合并单元格.设置单元格样式.边框的方法.需要的朋友参考下 今天在做项目中,遇到使用代码生成具有一定样式的Excel,找了很多资料,最后终于解决了,Ex ...

  9. Python快速设置Excel表格边框

    import xlwings as xw #打开存好的excel app = xw.App() #设置应用 wb = xw.Book("E:/Data/小蜜蜂超市销售报表.xlsx" ...

随机推荐

  1. Codeforces 311B Cats Transport 斜率优化dp

    Cats Transport 出发时间居然能是负的,我服了... 卡了我十几次, 我一直以为斜率优化写搓了. 我们能得出dp方程式 dp[ i ][ j ] = min(dp[ k ][ j - 1 ...

  2. MySQL Binlog 解析工具 Maxwell 详解

    maxwell 简介 Maxwell是一个能实时读取MySQL二进制日志binlog,并生成 JSON 格式的消息,作为生产者发送给 Kafka,Kinesis.RabbitMQ.Redis.Goog ...

  3. hdu 4438 第37届ACM/ICPC 天津赛区现场赛H题

    题意:Alice和Bob两个人去打猎,有两种(只)猎物老虎和狼: 杀死老虎得分x,狼得分y: 如果两个人都选择同样的猎物,则Alice得分的概率是p,则Bob得分的概率是(1-p): 但是Alice事 ...

  4. 某题目2 状压DP

    Description 对于一个数列,其混乱度定义为连续相等的数的段数.如:1 2 1 2 1,其混乱度为5,而:1 2 2 3 3,其混乱度为3.现给出一个数列,允许取出k个数并允许插入数列中的任意 ...

  5. 数据库事务的属性-ACID和隔离级别

    1.数据库事务的属性-ACID(四个英文单词的首写字母): 1)原子性(Atomicity) 所谓原子性就是将一组操作作为一个操作单元,是原子操作,即要么全部执行,要么全部不执行. 2)一致性(Con ...

  6. Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) C. Ray Tracing 数学

    C. Ray Tracing 题目连接: http://codeforces.com/contest/724/problem/C Description oThere are k sensors lo ...

  7. CentOS内核优化提示:cannot stat /proc/sys/net/bridge/bridge-nf-call-ip6tables: 没有那个文件或目录

    临时解决,重启失效 modprobe br_netfilter 为了开机加载上面这个模块 cat > /etc/rc.sysinit << EOF #!/bin/bash for f ...

  8. CentOS安装openvpn报错:error: route utility is required but missing

    centos7特有,直接安装net-tools即可. 参考: https://forums.openvpn.net/viewtopic.php?t=21432

  9. Mac 10.12彻底关闭Dashboard

    1.打开[系统偏好设置]. 2.点击进入[Mission Control]. 3.中间有一项[Dashboard],点击它右边的下拉菜单,选择[关闭],即可.

  10. 项目内部IT/电商/信息化类简报,分享电子版

    除了一些国内不准发的内容,还有公司内部项目相关的.其他的大多数资料会在微信公众号推送,分享一下吧,希望大家也能推荐一些好文章. 微信公众号:WallinWind,原创IT类文章在CSDN博客也会同步更 ...