
怎么样,效果还行吧,有没有达到你心目中的标准?如果你也遇到了这样的问题,那么请静下心来花费几分钟时间,我会详细的梳理出自己的思路,希望能够帮助到你。
1.首先,我们来看一下树形结构的数据、正如效果图一样,我这里处理的是一个三层结构。
---- 祖先节点(包含祖先节点id,祖先节点name,children,total(当前对象的第三级子节点的数量))
---父亲节点(包含祖先节点id,祖先节点name,本身的id,本身的name,children)
----子节点(包含上面两个祖先的数据和自己本身的数据,无children)
数据是提前处理好了的,在代码里的体现就是一个集合List ,StatisticsByPartVo是一个java bean对象,是个树形结构。
2.因为涉及到表格的合并,我再提一下关键的代码
sheet0.addMergedRegion(new CellRangeAddress(Parma1,Parma2,Parma3,Parma4));
四个参数分别表示
Parma1:要合并的开始行
Parma2:要合并的结束行
Parma3:要合并的开始列
Parma4:要合并的结束列
举个例子,因为坐标都是从(0,0)开始的,我要合并三行四列,参数就是(2,2,3,3)
现在开始整理一下整体思路:循环整个list集合,用HSSFRow 来创建行,用HSSFCell来创建一行的一个元素,在循环的过程中,将需要合并的数据的坐标,单独用一个List。
怕一段文字太多影响你们阅读,我上面说的是总体思路,下面我再简单说一下针对我这个demo和数据的逻辑。
1.循环整个list,得到当前对象StatisticsByPartVo,取到StatisticsByPartVo的total,根据total的值和当前rowNum的值,来为第一级添加坐标,我代码里添加了两次,因为序号也是跟第一级一起合并的。
2.循环当前对象StatisticsByPartVo的children,也是一个集合,得到当前对象secondChild,在循环secondChild的children,分别创建行列,在secondChild的children循环完毕后,为第二级添加坐标,代码的231行,其中注意rowNum和curNum等计数器的变化和位置,如果这个有错也会导致表格格式不对。
3.循环完之后,循环计步集合,合并表格,整体完毕
for(Mapmap:stepList){
sheet0.addMergedRegion(new CellRangeAddress(map.get("startIndexRow"), map.get("endIndexRow"), map.get("startIndexCol"), map.get("endIndexCol")));
}
以上就是我的整体思路,如果你也被这个问题困扰,不如跟着我的思路走一下,整体代码和逻辑都不复杂,如果我的文章能够帮助你解决掉问题,别吝啬你的小指头给作者点个赞哦。
下面贴上完整逻辑代码,关键地方已经打上注释,欢迎下方留言,有不对的地方欢迎指出。转载请附上原文链接。
package cdcb.govpublic.base.entity;
import cdcb.util.PropertiesUtils;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.CellRangeAddress;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.FileInputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @author wq
* @date 2020/4/2.
*/
public class StatisticsByPartView {
public StatisticsByPartView() {
}
public static void buildExcelDocument(Map mode, HttpServletRequest request, HttpServletResponse response,String year) throws Exception {
String path = PropertiesUtils.getValueByKey("excelPath", request.getServletContext().getRealPath("/"));
String excelModelPath = path + "static/template/listByPart.xls";
File excel = new File(excelModelPath);
FileInputStream is = new FileInputStream(excel);
Workbook workbook = new HSSFWorkbook(is);
is.close();
String excelName = year+"年政府网各栏目数据报送情况汇总表";
//这个方法就是主要创建逻辑方法
setWorkBookValue(workbook, mode,excelName);
String userAgent = request.getHeader("User-Agent");
userAgent = userAgent == null ? "" : userAgent.toLowerCase();
if (!userAgent.contains("msie") && !userAgent.contains("trident")) {
excelName = new String(excelName.getBytes(), "iso-8859-1");
} else {
excelName = URLEncoder.encode(excelName, "UTF-8");
}
response.setContentType("application/octet-stream");
response.setHeader("Content-disposition", "attachment;filename=\"" + excelName + ".xls\"");
OutputStream ouputStream = response.getOutputStream();
workbook.write(ouputStream);
ouputStream.flush();
ouputStream.close();
}
private static void setWorkBookValue(Workbook wbs, Map model,String excelName) {
List list = (List)model.get("list");
HSSFCellStyle style = (HSSFCellStyle)wbs.createCellStyle();
style.setVerticalAlignment((short)1);
style.setAlignment((short)2);
style.setWrapText(false);
style.setBorderBottom((short)1);
style.setBorderRight((short)1);
style.setBorderTop((short)1);
style.setBorderLeft((short)1);
//这里设置style2的目的是给下面的循环做判断,如果数据为零则加粗标红
HSSFCellStyle style2 = (HSSFCellStyle) wbs.createCellStyle();
style2.setVerticalAlignment((short) 1);
style2.setAlignment((short) 2);
style2.setWrapText(false);
style2.setBorderBottom((short) 1);
style2.setBorderRight((short) 1);
style2.setBorderTop((short) 1);
style2.setBorderLeft((short) 1);
Font ztFont = wbs.createFont();
ztFont.setColor(Font.COLOR_RED);
ztFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
style2.setFont(ztFont);
//创建工作簿
HSSFSheet sheet0 = (HSSFSheet)wbs.getSheetAt(0);
//记录步数的集合
List