POI实现EXCEL单元格合并及边框样式
POI实现EXCEL单元格合并及边框样式
下面例子为创建产生一个excel,合并单元格,然后为合并后的单元格添加边框
- package test;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import org.apache.poi.hssf.usermodel.HSSFCell;
- import org.apache.poi.hssf.usermodel.HSSFCellStyle;
- import org.apache.poi.hssf.usermodel.HSSFRow;
- import org.apache.poi.hssf.usermodel.HSSFSheet;
- import org.apache.poi.hssf.usermodel.HSSFWorkbook;
- import org.apache.poi.ss.usermodel.BorderStyle;
- import org.apache.poi.ss.usermodel.Font;
- import org.apache.poi.ss.usermodel.HorizontalAlignment;
- import org.apache.poi.ss.util.CellRangeAddress;
- import org.apache.poi.ss.util.RegionUtil;
- public class ExcelPoiTest {
- public static void main(String[] args) {
- HSSFWorkbook workbook = new HSSFWorkbook(); // 创建一个excel
- // excel生成过程: excel-->sheet-->row-->cell
- HSSFSheet sheet = workbook.createSheet("test"); // 为excel创建一个名为test的sheet页
- HSSFRow row = sheet.createRow(1); // 创建一行,参数2表示第一行
- HSSFCell cellB2 = row.createCell(1); // 在B2位置创建一个单元格
- HSSFCell cellB3 = row.createCell(2); // 在B3位置创建一个单元格
- cellB2.setCellValue("单元格B2"); // B2单元格填充内容
- cellB3.setCellValue("单元格B3"); // B3单元格填充内容
- HSSFCellStyle cellStyle = workbook.createCellStyle(); // 单元格样式
- Font fontStyle = workbook.createFont(); // 字体样式
- fontStyle.setBold(true); // 加粗
- fontStyle.setFontName("黑体"); // 字体
- fontStyle.setFontHeightInPoints((short) 11); // 大小
- // 将字体样式添加到单元格样式中
- cellStyle.setFont(fontStyle);
- // 边框,居中
- cellStyle.setAlignment(HorizontalAlignment.CENTER);
- cellStyle.setBorderBottom(BorderStyle.THIN);
- cellStyle.setBorderLeft(BorderStyle.THIN);
- cellStyle.setBorderRight(BorderStyle.THIN);
- cellStyle.setBorderTop(BorderStyle.THIN);
- cellB2.setCellStyle(cellStyle); // 为B2单元格添加样式
- // 合并单元格
- CellRangeAddress cra =new CellRangeAddress(1, 3, 1, 3); // 起始行, 终止行, 起始列, 终止列
- sheet.addMergedRegion(cra);
- // 使用RegionUtil类为合并后的单元格添加边框
- RegionUtil.setBorderBottom(1, cra, sheet); // 下边框
- RegionUtil.setBorderLeft(1, cra, sheet); // 左边框
- RegionUtil.setBorderRight(1, cra, sheet); // 有边框
- RegionUtil.setBorderTop(1, cra, sheet); // 上边框
- // 输出到本地
- String excelName = "/myExcel.xls";
- FileOutputStream out = null;
- try {
- out = new FileOutputStream(excelName);
- workbook.write(out);
- out.flush();
- out.close();
- } catch (Exception e) {
- e.printStackTrace();
- } finally {
- if (out != null)
- try {
- out.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- out = null;
- }
- }
- }
1.excel生成过程: excel-->sheet-->row-->cell
2.索引从0开始
3.合并单元格后保留最左上角的单元格(B3单元格被B2单元格覆盖)
4.合并后单元格边框通过RegionUtil设置,如果删除以下代码
- <span style="font-size:18px;"><strong> // 使用RegionUtil类为合并后的单元格添加边框
- RegionUtil.setBorderBottom(1, cra, sheet); // 下边框
- RegionUtil.setBorderLeft(1, cra, sheet); // 左边框
- RegionUtil.setBorderRight(1, cra, sheet); // 有边框
- RegionUtil.setBorderTop(1, cra, sheet); // 上边框</strong></span>
效果为:
可以看到只有B2单元格有边框。
java poi 合并单元格
- XSSFWorkbook wb = new XSSFWorkbook();
- XSSFSheet sheet = wb.createSheet();
- //这个就是合并单元格
- //参数说明:1:开始行 2:结束行 3:开始列 4:结束列
- //比如我要合并 第二行到第四行的 第六列到第八列 sheet.addMergedRegion(new CellRangeAddress(1,3,5,7));
- sheet.addMergedRegion(new CellRangeAddress(0,0,0,1));
- XSSFRow row = sheet.createRow(number);
需要注意的地方(不对的地方请指教)
感觉唯一要注意的地方就是:需要先设置 合并单元格,然后再 生成 行。
比如我们要生成的单元格为:
| 1工作站 | 左位置 | 1序号 | 2000订单号 | 1成品号/型号 |
| 左位置 | 2序号 | |||
| 左位置 | 3序号 | |||
| 右位置 | 4序号 |
代码可以这样写:
- sheet.addMergedRegion(new CellRangeAddress(0,3,0,0));
- sheet.addMergedRegion(new CellRangeAddress(0,3,3,3));
- sheet.addMergedRegion(new CellRangeAddress(0,3,4,4));
- //第一行数据
- XSSFRow row = sheet.createRow(0);
- row.createCell(0).setCellValue("工作站");
- row.createCell(1).setCellValue("位置");
- row.createCell(2).setCellValue("序号");
- row.createCell(3).setCellValue("订单号");
- row.createCell(4).setCellValue("成品号/型号");
- //第二行数据
- XSSFRow row = sheet.createRow(number);
- //row.createCell(0).setCellValue("工作站");//因为和上面的行合并了,所以不用再次 赋值了
- row.createCell(1).setCellValue("位置");
- row.createCell(2).setCellValue("序号");
- //row.createCell(3).setCellValue("订单号");//因为和上面的行合并了,所以不用再次 赋值了
- //row.createCell(4).setCellValue("成品号/型号");//因为和上面的行合并了,所以不用再次 赋值了
第三行数据和 第二行是一样的
POI实现EXCEL单元格合并及边框样式的更多相关文章
- POI对Excel单元格进行颜色设置
POI对Excel单元格进行颜色设置 学习了:http://www.myexception.cn/program/1932587.html HSSFWorkbook workbook = new HS ...
- 修复Java使用POI合并Excel单元格后,边框不显示的问题
使用Apache POI生成Excel文档时,当进行单元格合并操作后,被合并的单元格边框会消失,使用如下方式可以解决. 创建方法: public void setBorderStyle(int bor ...
- POI获取excel单元格红色字体,淡蓝色前景色的内容
如果是Microsoft Excel 97-2003 工作表 (.xls) if(31 == cell.getCellStyle().getFillForegroundColor()) //判断单元格 ...
- php实现excel单元格合并,字体加粗居中等操作
使用的是phpexcel,基本用的原生语法,所见即所得,直接复制下面代码,即可: // 引用phpexcel类 $this->load->library('PHPExcel'); // 创 ...
- java POI实现Excel单元格数据换行
当我们通过POI设置了表格的列宽的时候,如果文字过长,希望文字能够自己折行显示. 截取代码如下: Workbook wb = new XSSFWorkbook(); //or new HSSFWork ...
- C# 解决EXCEL单元格合并,行高无法自适应问题
解决方法:根据单元格内容长度,设置单元格所在行的行高 public static float getExcelCellAutoHeight(string strtest, float fontCoun ...
- POI 设置Excel单元格背景色(setFillForegroundColor)
背景介绍:使用Java开发信息系统项目,项目中往往会涉及到报表管理部分,而Excel表格首当其冲称为最合适的选择,但是对单元格操作时对于设置单元格的背景颜色却很少提及,本文旨在方便单元格背景颜色设计. ...
- NPOI设置Excel单元格字体、边框、对齐、背景色
代码: ICellStyle cellStyle = workbook.CreateCellStyle(); cellStyle.BorderBottom = BorderStyle.Thin; ce ...
- poi 取excel单元格内容时,需要判断单元格的类型,才能正确取出
以下内容非原创,原文链接http://blog.sina.com.cn/s/blog_4b5bc01101015iuq.html ate String getCellValue(HSSFCell ce ...
随机推荐
- 第十五篇 make中的隐式规则概述
前面我们讲到了makefile的依赖拆分的知识,现在可以引申出这样一个问题,如果同一个目标的不同命令拆分的写到不同地方会发生什么?下面我们给出程序和执行结果: 可见后面的命令会覆盖前面的命令, ...
- Codeforces gym101955 A【树形dp】
LINK 有n个大号和m个小号 然后需要对这些号进行匹配,一个大号最多匹配2个小号 匹配条件是大号和小号构成了前缀关系 字符串长度不超过10 问方案数 思路 因为要构成前缀关系 所以就考虑在trie树 ...
- Python 操作Excel之通过xlutils实现在保留原格式的情况下追加写入数据
在Python操作Excel 的模块有 xlrd.xlwt.xlutils等. xlrd:读取Excel文件数据 xlwt:写入Excel 数据,缺点是Excel格式无法复用,为了方便用户,写入的话, ...
- hdu 5311(暴力)
题意:要求在一个字符串中找出三段,然后能拼成一个固定的单词,问是否可行 BC周年庆第二题,我枚举了那个单词的切断位置,然后到给的字符串里分别找,然后就没有然后了``` #include<stdi ...
- Django中提供了6种缓存方式
开发调试 内存 文件 数据库 Memcache缓存(python-memcached模块) Memcache缓存(pylibmc模块) 1. 开发调试 1 2 3 4 5 6 7 8 9 10 11 ...
- day40 python MySQL【四】 之 【索引】【视图】【触发器】【存储过程】【函数】
MySQL[四] 之 [索引][视图][触发器][存储过程][函数] 1.索引 索引相当于图书的目录,可以帮助用户快速的找到需要的内容. 数据库利用各种各样的快速定位技术,能够大大提高查询效率.特 ...
- 【MVC】VS常用技巧
1,在VS2010中,选中指定的代码段,可以拖拽到工具箱中,形成标签,以后还想书写类似的代码,双击鼠标即可. 2,在VS2012中,可以在注释上标注//TODO:我是注释 这样,注释就会出现在任务列表 ...
- Nginx 下部署 HTTPS 与安全调优
什么是 HTTPS?# HTTPS(全称:Hyper Text Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP的 ...
- Spring Cloud 入门 之 Zuul 篇(五)
原文地址:Spring Cloud 入门 之 Zuul 篇(五) 博客地址:http://www.extlight.com 一.前言 随着业务的扩展,微服务会不对增加,相应的其对外开放的 API 接口 ...
- The superclass "javax.servlet.http.HttpServlet" was not found
在eclipse中,需要通过