• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > java实现合并单元格的同时并导出excel示例

java实现合并单元格的同时并导出excel示例

作者:chuquan.ou 字体:[增加 减小] 来源:互联网 时间:2017-05-28

chuquan.ou 通过本文主要向大家介绍了java合并单元格,java excel合并单元格,java poi合并单元格,java中合并单元格,设置单元格格式示例等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

介绍

POI提供API给Java程序对Microsoft Office格式档案读和写的功能。POI可以操作的文档格式有excel,word,powerpoint等,POI进行跨行需要用到对象HSSFSheet对象,现在就当我们程序已经定义了一个HSSFSheet对象sheet。

跨第1行第1个到第2个单元格的操作为

sheet.addMergedRegion(new Region(0,(short)0,0,(short)1)); 
</div>

跨第1行第1个到第2行第1个单元格的操作为

sheet.addMergedRegion(new Region(0,(short)0,1,(short)0)); 
</div>

重点注意事项:

     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();  
  }  
  
 }  
  
} 
</div>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • java实现合并单元格的同时并导出excel示例

相关文章

  • 2017-05-28java版简单的猜数字游戏实例代码
  • 2017-05-28Java中的FileInputStream 和 FileOutputStream 介绍_动力节点Java学院整理
  • 2017-05-28Java实现一个达达租车系统的步骤详解
  • 2017-05-28MyBatis框架简介
  • 2017-05-28SpringMVC接收页面表单参数
  • 2017-05-28Java 可视化垃圾回收_动力节点Java学院整理
  • 2017-05-28详谈Lock与synchronized 的区别
  • 2017-05-28二维码生成Java实现代码
  • 2017-05-28详解SpringBoot多跨域请求的支持(JSONP)
  • 2017-05-28Java Socket编程(五) 简单的WEB服务器

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 详解MyBatis批量插入数据Mapper配置文件的写法
    • 利用spring aop实现动态代理
    • Java多线程并发编程(互斥锁Reentrant Lock)
    • Map获取键值,Map的几种遍历方法总结(推荐)
    • Java工程中使用Mybatis (工程结合Mybatis,数据结合Swing使用))
    • 命令提示符编译java的方法(必看篇)
    • SpringMVC中Json数据格式转换
    • java中hibernate二级缓存详解
    • Spring MVC 基于URL的映射规则(注解版)
    • Java System类详解_动力节点Java学院整理

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有