java poi 跨行合并 并赋值

2023-11-02 05:10
文章标签 java 合并 赋值 poi 跨行

本文主要是介绍java poi 跨行合并 并赋值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

所需jar包   https://download.csdn.net/my

@Override
public InputStream getExcelUserId(int id,User user) {
// TODO Auto-generated method stub
HSSFWorkbook book = new HSSFWorkbook();     
//获取审核人数
String useName=user.getUsername();//获取审核人员名称
// 创建一个sheet,并命名
HSSFSheet sheet = book.createSheet(useName);
// 1.生成字体对象  
HSSFFont font = book.createFont();  
font.setFontHeightInPoints((short) 10);  
font.setFontName("新宋体");  
font.setColor(HSSFColor.BLUE.index);  
font.setBoldweight((short) 0.8);  
// 2.生成样式对象  
HSSFCellStyle style = book.createCellStyle();  
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);  
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);  
style.setFont(font); // 调用字体样式对象  

style.setWrapText(true);  

String [] headers={"一级标题","权重","二级标题","权重","三级标题","权重","评价要点","计分方法","数据来源","打分"};

                //生成标题,第一行标题默认下标为:0,这里 sheet.createRow(0);创建第一行

HSSFRow row = sheet.createRow(0); // 产生表格标题行    
for (int j = 0; j < headers.length; j++) {  
HSSFCell cell = row.createCell(j);  
HSSFRichTextString text = new HSSFRichTextString(headers[j]);  
cell.setCellValue(text);  
}  
//循环赋值,先创建所有单元格,要合并的单元个再创建完成后再获取单元格赋值并合并
List<WebThreeIndex> listThree=webDao.getWebThreeIndexImage(id,user.getId());
if(listThree.size()>0&&listThree!=null){
for(int t=0;t<listThree.size();t++){
WebThreeIndex webThreeIndex=listThree.get(t);
HSSFRow row1 = sheet.createRow(t+1);//三级标题名称数据
HSSFCell hc0 = row1.createCell(0);
 //这里是没有写入数据的单元个,如果后面想要获取此处单元格并赋值就必须给一个值
hc0.setCellValue(new HSSFRichTextString(" "));
HSSFCell hc1 = row1.createCell(1);
hc1.setCellValue(new HSSFRichTextString(" "));   
HSSFCell hc2 = row1.createCell(2);
hc2.setCellValue(new HSSFRichTextString(" "));   
HSSFCell hc3 = row1.createCell(3);
hc3.setCellValue(new HSSFRichTextString(" "));   
HSSFCell hc4 = row1.createCell(4);
hc4.setCellValue(new HSSFRichTextString(webThreeIndex.getThree_index()));   
HSSFCell hc5 = row1.createCell(5);
hc5.setCellValue(new HSSFRichTextString(webThreeIndex.getWeight()));
HSSFCell hc6 = row1.createCell(6);
hc6.setCellValue(new HSSFRichTextString(webThreeIndex.getEvaluate()));
HSSFCell hc7 = row1.createCell(7);
hc7.setCellValue(new HSSFRichTextString(webThreeIndex.getScoring_method()));
HSSFCell hc8 = row1.createCell(8);
hc8.setCellValue(new HSSFRichTextString(webThreeIndex.getData_sources()));
HSSFCell hc9 = row1.createCell(9);
hc9.setCellStyle(style);
hc9.setCellValue(new HSSFRichTextString(webThreeIndex.getSjscore()));
}
}
//创建单元个结束
//给一级标题和权重赋值并合并
List<WebOneIndex> listOne=webDao.getWebOneIndex();//获取一级标题数据
if(listOne.size()>0&&listOne!=null){
int n=1;
for(int j=0;j<listOne.size();j++){
WebOneIndex webOneIndex=listOne.get(j);
List<WebThreeIndex> threeList=webDao.getWebThreeIndex(webOneIndex.getId());//获取三级级指标数据
int lie=threeList.size();//获取一级指标所跨行数
HSSFRow row5 = sheet.getRow(n);  
if(j==0){//第一次是从下标为1开始,0是标题
// CellRangeAddress(1, lie, 0, 0)) 开始行,结束行,开始列,结束列
sheet.addMergedRegion(new CellRangeAddress(1, lie, 0, 0)); 
HSSFCell cell0 = row5.getCell(0);// 获得第五行的第四个单元格 
cell0.setCellStyle(style);  
cell0.setCellValue(webOneIndex.getOne_index());// 给单元格赋值 
sheet.addMergedRegion(new CellRangeAddress(1, lie, 1, 1)); 
HSSFCell cell1 = row5.getCell(1);
cell1.setCellStyle(style);
cell1.setCellValue(webOneIndex.getWeight());
n+=lie;
}else{
sheet.addMergedRegion(new CellRangeAddress(n, n+lie-1, 0, 0)); 
HSSFCell cell0 = row5.getCell(0);// 获得第五行的第四个单元格 
cell0.setCellStyle(style);
cell0.setCellValue(webOneIndex.getOne_index());// 给单元格赋值 
sheet.addMergedRegion(new CellRangeAddress(n, n+lie-1, 1, 1)); 
HSSFCell cell1 = row5.getCell(1);
cell1.setCellStyle(style);
cell1.setCellValue(webOneIndex.getWeight());
n+=lie;
}
}
}
List<WebTwoIndex> listTwo=webDao.getWebTwoIndex();
if(listTwo.size()>0&&listTwo!=null){
int n1=1;
for(int j=0;j<listTwo.size();j++){
WebTwoIndex WebTwoIndex=listTwo.get(j);
List<WebThreeIndex> threeList=webDao.getWebThreeIndexTwoId(WebTwoIndex.getId());
int lie=threeList.size();//获取一级指标所跨行数
HSSFRow row5 = sheet.getRow(n1); // 获得工作薄的第五行 
if(j==0){
sheet.addMergedRegion(new CellRangeAddress(1, n1+lie-1, 2, 2)); 
HSSFCell cell0 = row5.getCell(2);// 获得第五行的第四个单元格 
cell0.setCellStyle(style);
cell0.setCellValue(WebTwoIndex.getTwo_index());// 给单元格赋值 
sheet.addMergedRegion(new CellRangeAddress(1, n1+lie-1, 3, 3)); 
HSSFCell cell1 = row5.getCell(3);
cell1.setCellStyle(style);
cell1.setCellValue(WebTwoIndex.getWeight());
n1+=lie;
}else{
sheet.addMergedRegion(new CellRangeAddress(n1, n1+lie-1, 2, 2)); 
HSSFCell cell0 = row5.getCell(2);// 获得第五行的第四个单元格 
cell0.setCellStyle(style);
cell0.setCellValue(WebTwoIndex.getTwo_index());// 给单元格赋值 
sheet.addMergedRegion(new CellRangeAddress(n1, n1+lie-1, 3, 3)); 
HSSFCell cell1 = row5.getCell(3);
cell1.setCellStyle(style);
cell1.setCellValue(WebTwoIndex.getWeight());
n1+=lie;
}
}
}
Long time = System.currentTimeMillis();
String newFileName = String.valueOf(time)+".xlsx";//文件重命名,防止重复文件名
Properties prop = new Properties();
InputStream input = null;
String fileP = "";
try {
input = this.getClass().getResourceAsStream("/apiconfig.properties");// new
prop.load(input);
fileP = prop.getProperty("exportExcel") ;
} catch (Exception e) {
fileP = "C:/workspacess/zjts/UploadFile/";
}
File dir=new File(fileP);    
//判断文件是否上传,如果上传的话将会创建该目录   
if(!dir.exists()){    
dir.mkdirs(); //创建该目录   
}
File file = new File(fileP + newFileName);
try {
OutputStream output = new FileOutputStream(file);
book.write(output);
output.close();
} catch (Exception e) {
e.printStackTrace();
}
// 返回结果的文件输入文件流,到内存里方便下载
InputStream input1 = null;
try {
input1 = new FileInputStream(file);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
//删除生成的文件,减少服务器空间
if(file.exists()){
// file.delete();
}
return input1;
}

//上传样式



这篇关于java poi 跨行合并 并赋值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/328352

相关文章

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Java docx4j高效处理Word文档的实战指南

《Javadocx4j高效处理Word文档的实战指南》对于需要在Java应用程序中生成、修改或处理Word文档的开发者来说,docx4j是一个强大而专业的选择,下面我们就来看看docx4j的具体使用... 目录引言一、环境准备与基础配置1.1 Maven依赖配置1.2 初始化测试类二、增强版文档操作示例2.

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Java中Integer128陷阱

《Java中Integer128陷阱》本文主要介绍了Java中Integer与int的区别及装箱拆箱机制,重点指出-128至127范围内的Integer值会复用缓存对象,导致==比较结果为true,下... 目录一、Integer和int的联系1.1 Integer和int的区别1.2 Integer和in

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.