java合并单元格同时导出excel
POI进行跨行需要用到对象HSSFSheet对象,现在就当我们程序已经定义了一个HSSFSheet对象sheet。
跨第1行第1个到第2个单元格的操作为
sheet.addMergedRegion(new Region(0,(short)0,0,(short)1));
跨第1行第1个到第2行第1个单元格的操作为
sheet.addMergedRegion(new Region(0,(short)0,1,(short)0));
重点注意事项:
1.单元格CELL和ROW对象下标都是从0开始的。
2.单元格合并时Region(1,2,3,4)第1个值的行号必须要比3位置的行号小,如果大于3就不能正常合并单元格
3.合并单元格的时候要合并的单单元格必须先创建,这样方便后面再次获取这个单元格来填充数据,主要就是因为合并时不能由后向前进行合并引起的。
- 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.hssf.util.Region;
- public class ExcelTest {
- /**
- * @param args
- */
- public static void main(String[] args) throws IOException {
- try {
- HSSFWorkbook wb = new HSSFWorkbook();
- HSSFSheet sheet = wb.createSheet("new sheet");
- HSSFCellStyle style = wb.createCellStyle(); // 样式对象
- style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 垂直
- style.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平
- HSSFRow row = sheet.createRow((short) 0);
- HSSFRow row2 = sheet.createRow((short) 1);
- sheet.addMergedRegion(new Region(0, (short) 0, 1, (short) 0));
- HSSFCell ce = row.createCell((short) 0);
- ce.setEncoding(HSSFCell.ENCODING_UTF_16);// 中文处理
- ce.setCellValue("项目\\日期"); // 表格的第一行第一列显示的数据
- ce.setCellStyle(style); // 样式,居中
- int num = 0;
- for (int i = 0; i < 9; i++) { // 循环9次,每一次都要跨单元格显示
- // 计算从那个单元格跨到那一格
- int celln = 0;
- int celle = 0;
- if (i == 0) {
- celln = 0;
- celle = 1;
- } else {
- celln = (i * 2);
- celle = (i * 2 + 1);
- }
- // 单元格合并
- // 四个参数分别是:起始行,起始列,结束行,结束列
- sheet.addMergedRegion(new Region(0, (short) (celln + 1), 0,
- (short) (celle + 1)));
- HSSFCell cell = row.createCell((short) (celln + 1));
- cell.setCellValue("merging" + i); // 跨单元格显示的数据
- cell.setCellStyle(style); // 样式
- // 不跨单元格显示的数据,如:分两行,上一行分别两格为一格,下一行就为两格,“数量”,“金额”
- HSSFCell cell1 = row2.createCell((short) celle);
- HSSFCell cell2 = row2.createCell((short) (celle + 1));
- cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
- cell1.setCellValue("数量");
- cell1.setCellStyle(style);
- cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
- cell2.setCellValue("金额");
- cell2.setCellStyle(style);
- num++;
- }
- // 在后面加上合计百分比
- // 合计 在最后加上,还要跨一个单元格
- sheet.addMergedRegion(new Region(0, (short) (2 * num + 1), 0,
- (short) (2 * num + 2)));
- HSSFCell cell = row.createCell((short) (2 * num + 1));
- cell.setEncoding(HSSFCell.ENCODING_UTF_16);
- cell.setCellValue("合计");
- cell.setCellStyle(style);
- HSSFCell cell1 = row2.createCell((short) (2 * num + 1));
- HSSFCell cell2 = row2.createCell((short) (2 * num + 2));
- cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
- cell1.setCellValue("数量");
- cell1.setCellStyle(style);
- cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
- cell2.setCellValue("金额");
- cell2.setCellStyle(style);
- // 百分比 同上
- sheet.addMergedRegion(new Region(0, (short) (2 * num + 3), 0,
- (short) (2 * num + 4)));
- HSSFCell cellb = row.createCell((short) (2 * num + 3));
- cellb.setEncoding(HSSFCell.ENCODING_UTF_16);
- cellb.setCellValue("百分比");
- cellb.setCellStyle(style);
- HSSFCell cellb1 = row2.createCell((short) (2 * num + 3));
- HSSFCell cellb2 = row2.createCell((short) (2 * num + 4));
- cellb1.setEncoding(HSSFCell.ENCODING_UTF_16);
- cellb1.setCellValue("数量");
- cellb1.setCellStyle(style);
- cellb2.setEncoding(HSSFCell.ENCODING_UTF_16);
- cellb2.setCellValue("金额");
- cellb2.setCellStyle(style);
- /***这里是问题的关键,将这个工作簿写入到一个流中就可以输出相应的名字,这里需要写路径就ok了。
- FileOutputStream fileOut = new FileOutputStream("workbook.xls");
- wb.write(fileOut);
- fileOut.close();
- **/
- /**第二种是输出到也面中的excel名称
- * pName="栏目统计表";
- response.reset();
- response.setContentType("application/x-msdownload");
- response.setHeader("Content-Disposition","attachment; filename="+new String(pName.getBytes("gb2312"),"ISO-8859-1")+".xls");
- ServletOutputStream outStream=null;
- try{
- outStream = response.getOutputStream();
- wb.write(outStream);
- }catch(Exception e)
- {
- e.printStackTrace();
- }finally{
- outStream.close();
- }
- * */
- System.out.print("OK");
- } catch (Exception ex) {
- ex.printStackTrace();
- }
- }
- }
java合并单元格同时导出excel的更多相关文章
- poi合并单元格同时导出excel
poi合并单元格同时导出excel POI进行跨行需要用到对象HSSFSheet对象,现在就当我们程序已经定义了一个HSSFSheet对象sheet. 跨第1行第1个到第2个单元格的操作为 sheet ...
- php 数据导出到excel 2种带有合并单元格的导出
具体业务层面 可能会有所不同.以下两种方式涉及的合并单元格地方有所不同,不过基本思路是一致的. 第一种是非插件版本.可能更容易理解点,基本思路就是 组装table 然后 读取 输出到excel上.缺点 ...
- asp.net C#取Excel 合并单元格内容
asp教程.net c#取excel 合并单元格内容读取excel数据,填充dataset// 连接字符串 string xlspath = server.mappath("~/www.11 ...
- java导出标题多行且合并单元格的EXCEL
场景:项目中遇到有需要导出Excel的需求,并且是多行标题且有合并单元格的,参考网上的文章,加上自己的理解,封装成了可自由扩展的导出工具 先上效果,再贴代码: 调用工具类进行导出: public st ...
- java poi导出Excel合并单元格并设置边框
import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; i ...
- Java导出Excel表,POI 实现合并单元格以及列自适应宽度(转载)
POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...
- poi导出Excel报表多表头双层表头、合并单元格
效果图: controller层方法: /** * * 导出Excel报表 * @param request * @return * */ @ ...
- poi导出excel合并单元格(包括列合并、行合并)
1 工程所需jar包如下:commons-codec-1.5.jarcommons-logging-1.1.jarlog4j-1.2.13.jarjunit-3.8.1.jarpoi-3.9-2012 ...
- 在Asp.Net MVC中使用NPOI插件实现对Excel的操作(导入,导出,合并单元格,设置样式,输入公式)
前言 NPOI 是 POI 项目的.NET版本,它不使用 Office COM 组件,不需要安装 Microsoft Office,目前支持 Office 2003 和 2007 版本. 1.整个Ex ...
随机推荐
- Tpcc-MySQL对mysql数据库进行性能测试报告、分析及使用gnuplot生成图表展示
TPC-C是专门针对联机交易处理系统(OLTP系统)的规范,一般情况下我们也把这类系统称为业务处理系统. tpcc-mysql是percona基于TPC-C(下面简写成TPCC)衍生出来的产品,专用于 ...
- mysql5.6.13通用二进制格式安装并使用amoeba实现对mysql5.6数据库读写分离
proxy 192.168.8.39 master 192.168.8.40 slave 192.168.8.20 一.安装mysql-5.6.13服务器 安装包: mysql-5.6.13-linu ...
- 电信运营商 IT 系统介绍
业务支撑系统 BSS: Business support system 运营支撑系统 OSS: Operation support system 管理支撑系统 MSS: Management Su ...
- 在try-catch机制优化IO流关闭时,OutputStreamWriter 数据流被截断
1.前言 try-catch常规的格式是try{……}catch(){……}finallly{……},如果优化成try(……){……}catch(){……}finallly{……},此时流就可以自动关 ...
- javascript 什么类型没有toString()?
JS里面任何对象都有toString()方法么?不是! null和undefined就没有!虽然null用typeof看的时候,是object类型的. 另外number对象调用toString()会报 ...
- poj3061 poj3320 poj2566尺取法基础(一)
poj3061 给定一个序列找出最短的子序列长度,使得其和大于等于S 那么只要用两个下标,区间和小于S时右端点向右移动,区间和大于S时左端点向右移动,在这个过程中更新Min #include < ...
- hdu2838树状数组解逆序
离散化和排序后的序号问题搞得我实在是头痛 不过树状数组解逆序和偏序一类问题真的好用 更新:hdu的数据弱的真实,我交上去错的代价也对了.. 下面的代码是错的 /* 每个点的贡献度=权值*在这个点之前的 ...
- zoj3299 线段树区间更新,坐标建立线段树的方式
/* 平台和砖块的坐标离散化,边缘坐标转换成单位长度 处理下落信息,sum数组维护区间的砖块数量 把平台按高度从高到低排序,询问平台区间的砖块有多少,询问后将该区域砖块数置0 */ #include& ...
- python+selenium七:下拉框、选项框、select用法
# from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsimpo ...
- linux命令: chown命令
chown将指定文件的拥有者改为指定的用户或组,用户可以是用户名或者用户ID:组可以是组名或者组ID:文件是以空格分开的要改变权限的文件列表,支持通配符.系统管理员经常使用chown命令,在将文件拷贝 ...