精华内容
下载资源
问答
  • java导出excel复杂表头

    2019-02-20 16:09:50
    java工程,源代码,可直接运行,需自己改造成web下载方式。
  • java实现导出Excel多行表头复杂模板 一般我们都会选择poi来导出,选择一个比较好的ExcelUtils 但是对于初学者而言不了解poi的,还需从poi API文档去学习,如果是自学的话更好,如果是公司安排的任务,没有接触过有...
  • Java导出Excel 复杂表头

    2021-03-12 17:42:08
    文章标题导出表格依赖 导出表格 导出表格的方式在我的理解有两种 一种是直接用代码控制表头==== 简单的表头 一种是直接使用模板直接添加数据就可以=== 复杂的表头 依赖 <dependency> <groupId>org....

    文章标题

    导出表格

    导出表格的方式在我的理解有两种
    一种是直接用代码控制表头==== 简单的表头
    一种是直接使用模板直接添加数据就可以=== 复杂的表头

    依赖

    <dependency>
       <groupId>org.apache.poi</groupId>
       <artifactId>poi-ooxml</artifactId>
       <version>3.9</version>
    </dependency>
    
    <!--下面是我直接测试表格,因为要在浏览器导出,直接创建Springboot 简单访问-->
     <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
                <version>2.3.4.RELEASE</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>4.0.1</version>
            </dependency>
    
    package com.example.demo.test;
    
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import java.io.*;
    import java.net.URLEncoder;
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    /**
     * @program: Ecology1
     * @description: this is a class
     * @author: Mr.zeng
     * @create: 2021-03-12 10:02
     **/
    
    public class TestTemplateExcel {
        /*
         *
         */
        private static final long serialVersionUID = 1L;
    
        /**
         * 生成excel并下载
         */
        public void exportExcel(HttpServletResponse response, HttpServletRequest request) {
            String userName = request.getParameter("userName");
            File newFile = createNewFile();
            // File newFile = new File("d:/ss.xls");
            // 新文件写入数据,并下载*****************************************************
            InputStream is = null;
            Workbook workbook = null;
            Sheet sheet = null;
            try {
                is = new FileInputStream(newFile);// 将excel文件转为输入流
    
                workbook=XlsImpUtil.create(is);
    //            workbook = new XSSFWorkbook(is);// 创建个workbook,
                // 获取第一个sheet
                sheet = workbook.getSheetAt(0);
            } catch (Exception e1) {
                e1.printStackTrace();
            }
    
            if (sheet != null) {
                try {
                    // 写数据
                    FileOutputStream fos = new FileOutputStream(newFile);
                    Row row = sheet.getRow(3);
                    if (row == null) {
                        row = sheet.createRow(3);
                    }
                    Cell cell = row.getCell(0);
                    if (cell == null) {
                        cell = row.createCell(0);
                    }
    
                    // TODO 定义一个list集合假数据
                    List<Map<String, Object>> lst = new ArrayList();
                    Map<String, Object> map1 = new HashMap<String, Object>();
                    // 只能添加11个
                    for (int i = 0; i < 11; i++) {
                        map1.put("id" + i, i);
                        lst.add(map1);
                    }
                    row=sheet.getRow(1);
                    String sj="填报日期:2020年03月24日 15:52 星期四";
                    cell=row.getCell(0);
                    cell.setCellValue(sj);
                    for (int m = 0; m < lst.size(); m++) {
                        Map<String, Object> map = lst.get(m);
                        row=sheet.getRow(m+3);
    //                    row = sheet.createRow((int) m + 3);
                        for (int i = 0; i < 5; i++) {
                            String value = map.get("id" + m) + "";
                            if (value.equals("null")) {
                                value = "0";
                            }
                            if(row.getRowNum()>= 7 && row.getRowNum()<=12){
                                cell=row.getCell(i+2);
                            }else {
                                cell=row.getCell(i+2);
                            }
    
                        /*    cell = row.createCell(i);*/
                            cell.setCellValue(value);
                        }
    
                    }
                    // 填报人
                    row=sheet.getRow(14);
                    String tbr="\t\t填报人:"+userName;
                    cell=row.getCell(0);
                    cell.setCellValue(tbr);
    
                    workbook.write(fos);
                    fos.flush();
                    fos.close();
                    // 下载
                    InputStream fis = new BufferedInputStream(new FileInputStream(
                            newFile));
    //                    HttpServletResponse response = /*ServletActionContext.getResponse();*/null;
                    byte[] buffer = new byte[fis.available()];
                    fis.read(buffer);
                    fis.close();
                    response.reset();
                    response.setContentType("text/html;charset=UTF-8");
                    OutputStream toClient = new BufferedOutputStream(
                            response.getOutputStream());
                    response.setContentType("application/x-msdownload");
                    String newName = URLEncoder.encode(
                            "活动报表" + System.currentTimeMillis() + ".xlsx",
                            "UTF-8");
                    response.addHeader("Content-Disposition",
                            "attachment;filename=\"" + newName + "\"");
                    response.addHeader("Content-Length", "" + newFile.length());
                    toClient.write(buffer);
                    toClient.flush();
                } catch (Exception e) {
                    e.printStackTrace();
                } finally {
                    try {
                        if (null != is) {
                            is.close();
                        }
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }
            // 删除创建的新文件
             this.deleteFile(newFile);
        }
        /**
         * 复制文件
         *
         * @param s
         *            源文件
         * @param t
         *            复制到的新文件
         */
        public void fileChannelCopy(File s, File t) {
            try {
                InputStream in = null;
                OutputStream out = null;
                try {
                    in = new BufferedInputStream(new FileInputStream(s), 1024);
                    out = new BufferedOutputStream(new FileOutputStream(t), 1024);
                    byte[] buffer = new byte[1024];
                    int len;
                    while ((len = in.read(buffer)) != -1) {
                        out.write(buffer, 0, len);
                    }
                } finally {
                    if (null != in) {
                        in.close();
                    }
                    if (null != out) {
                        out.close();
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        private String getSispPath() {
            String classPaths = "C:\\Users\\zp\\IdeaProjects\\Ecology1\\src\\main\\resources";
    //        String classPaths="/usr/weaver/ecology/classbean/com/api/zp";
            String[] aa = classPaths.split("/");
            String sispPath = "";
            for (int i = 1; i < aa.length - 2; i++) {
                sispPath += aa[i] + "/";
            }
            return sispPath;
        }
        /**
         * 读取excel模板,并复制到新文件中供写入和下载
         *
         * @return
         */
        public File createNewFile() {
            // 读取模板,并赋值到新文件************************************************************
           final String name="C:\\Users\\zp\\IdeaProjects\\demo\\活动报表";
    //       String name="/usr/weaver/ecology/classbean/com/api/zp/活动报表";
            // 文件模板路径
            String path =  name+".xls";
            File file = new File(path);
            // 保存文件的路径
            String realPath =  "";
            // 新的文件名
            String newFileName = name + System.currentTimeMillis() + ".xls";
            // 判断路径是否存在
            File dir = new File(realPath);
            if (!dir.exists()) {
                dir.mkdirs();
            }
            // 写入到新的excel
            File newFile = new File(newFileName);
            try {
                newFile.createNewFile();
                // 复制模板到新文件
                fileChannelCopy(file, newFile);
            } catch (Exception e) {
                e.printStackTrace();
            }
            return newFile;
        }
        /**
         * 下载成功后删除
         *
         * @param files
         */
        private void deleteFile(File... files) {
            for (File file : files) {
                if (file.exists()) {
                    file.delete();
                }
            }
        }
        }
    
    
    import com.fasterxml.jackson.databind.exc.InvalidFormatException;
    import org.apache.poi.POIXMLDocument;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.openxml4j.opc.OPCPackage;
    import org.apache.poi.poifs.filesystem.POIFSFileSystem;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.PushbackInputStream;
    
    /**
     * @program: Ecology
     * @description: this is a class
     * @author: Mr.zeng
     * @create: 2021-03-12 11:34
     **/
    
    public class XlsImpUtil {
        public static Workbook create(InputStream inp) throws IOException, InvalidFormatException, org.apache.poi.openxml4j.exceptions.InvalidFormatException {
            if (!inp.markSupported()) {
                inp = new PushbackInputStream(inp, 8);
            }
            if (POIFSFileSystem.hasPOIFSHeader(inp)) {
                return new HSSFWorkbook(inp);
            }
            if (POIXMLDocument.hasOOXMLHeader(inp)) {
                return new XSSFWorkbook(OPCPackage.open(inp));
            }
            throw new IllegalArgumentException("你的excel版本目前poi解析不了");
        }
    }
    

    我的Controller

    import com.example.demo.test.TestTemplateExcel;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * @program: Ecology1
     * @description: this is a class
     * @author: Mr.zeng
     * @create: 2021-03-12 10:52
     **/
    @Controller
    @RequestMapping("/excel")
    public class ExcelMainController {
    
        @RequestMapping("/port")
        public String excelport(HttpServletResponse response, HttpServletRequest request){
             new TestTemplateExcel().exportExcel(response,request);
             return "";
        }
    }
    
    展开全文
  • java 生成excel多级表头导出

    千次阅读 2021-04-22 16:33:24
    依赖工具包 cn.hutool hutool-all 5.3.5 该工具包是对 Apache POI包... } 导出效果 标签:java,get,excel,getChildren,表头,merge,bigWriter,true,columns 来源: https://www.cnblogs.com/likun10579/p/14488063.html

    依赖工具包

    cn.hutool

    hutool-all

    5.3.5

    该工具包是对 Apache POI包的分装

    private void export(HttpServletResponse response, String fileName, List> projects, List columns) throws IOException {

    ExcelWriter bigWriter = ExcelUtil.getBigWriter();

    //创建一行空表头占个位置

    bigWriter.writeHeadRow(new LinkedList());

    //创建需要展示的的二级表头,{filedName,中文名}

    int lastCol = 0;

    for (int i = 0; i < columns.size(); i++) {

    if (columns.get(i).getChildren() != null) {

    for (int j = 0; j < columns.get(i).getChildren().size(); j++) {

    bigWriter.addHeaderAlias(columns.get(i).getChildren().get(j).getProp(), columns.get(i).getChildren().get(j).getLabel() + columns.get(i).getProp());

    bigWriter.setColumnWidth(lastCol++, 30);

    }

    }

    }

    //根据需要合并添加第一列表头

    bigWriter.merge(0, 1, 0, 0, columns.get(0).getLabel(), true);

    bigWriter.merge(0, 0, 1, 14, "第一类(个人)", true);

    bigWriter.merge(0, 0, 15, 28, "第一类(企业)", true);

    bigWriter.merge(0, 0, 29, 42, "第二类(个人)", true);

    bigWriter.merge(0, 0, 43, 56, "第二类(企业)", true);

    bigWriter.merge(0, 0, 57, 64, "总计项", true);

    // 只导出配置好的列名

    bigWriter.setOnlyAlias(true);

    bigWriter.write(projects, true);

    StyleSet styleSet = bigWriter.getStyleSet();

    styleSet.setWrapText();

    response.setContentType("application/vnd.ms-excel;charset=utf-8");

    response.setHeader("filename", URLEncoder.encode(fileName + ".xlsx", "UTF-8"));

    ServletOutputStream out = response.getOutputStream();

    bigWriter.flush(out, true);

    bigWriter.close();

    IoUtil.close(out);

    }

    导出效果

    58b1085cf671cfa9354f8c782659d834.png

    标签:java,get,excel,getChildren,表头,merge,bigWriter,true,columns

    来源: https://www.cnblogs.com/likun10579/p/14488063.html

    展开全文
  • 树精 poi多级表头衍生
  • POI--导出EXCEL多级表头通用方法

    千次阅读 2019-07-09 15:53:31
    //导出表头     public void exportHeadData(XSSFSheet sheet,St...

    //导出表头
        public void exportHeadData(XSSFSheet sheet,String[][] propertyDes,XSSFCellStyle style){
             //表头部分

           // 二级表头测试数据
            /*String[][] propertyDes = {{"姓名","所属部门","职位","入职日期","转正日期","年假","","带薪病假","","调休剩余可休天数","本月加班天数","本月已休","","","","","",""},
                    {"","","","","","基数","剩余可休天数","基数","剩余可休天数","","","年假","调休","带薪病假","婚假","产假","丧假","事假"}};*/

          //一级表头测试数据
            /*String[][] propertyDes = {{"姓名","所属部门","职位","入职日期","转正日期","年假","123","带薪病假","123","调休剩余可休天数","本月加班天数","本月已休","123","12","123","123","12","123"}};*/

        // 三级表头测试数据
            /*String[][] propertyDes = {{"1","","2","3","","",""},
                    {"1","1","","3","","3",""},{"","","","3","3","3","3"}};*/

       // 四级表头测试数据
            /*String[][] propertyDes = {{"1","","2","3","","","","4","","","","","","",""},
                    {"1","1","","3","","3","","4","","","","4","","",""},{"","","","3","3","3","3","4","","4","","4","","4",""},
                    {"","","","","","","","4","4","4","4","4","4","4","4"}};*/


            int mergerNum = 0 ; //合并数
            //给单元格设置值
            for(int i=0; i< propertyDes.length; i++){
                XSSFRow row = sheet.createRow(i);
                row.setHeight((short)700);
                for(int j=0; j<propertyDes[i].length; j++){
                    XSSFCell cell = row.createCell(j);
                    cell.setCellStyle(style);
                    cell.setCellValue(propertyDes[i][j]);
                }
            }
            Map<Integer,List<Integer>> map = new HashMap<Integer, List<Integer>>();   // 合并行时要跳过的行列
            //合并列
            for(int i=0; i<propertyDes[propertyDes.length-1].length; i++){
                if("".equals(propertyDes[propertyDes.length-1][i])){
                     for(int j=propertyDes.length-2; j >=0 ;j--){
                        if(!"".equals(propertyDes[j][i])){    
                            sheet.addMergedRegion(new CellRangeAddress(j,propertyDes.length-1,i,i)); // 合并单元格
                            break;
                        }else{
                            if(map.containsKey(j)){
                                List<Integer> list = map.get(j);
                                list.add(i);
                                map.put(j, list);
                            }else{
                                List<Integer> list = new ArrayList<Integer>();
                                list.add(i);
                                map.put(j, list);
                            }
                        }
                    }
                }
            }
            //合并行
            for(int i=0; i< propertyDes.length-1; i++){
                for(int j=0; j<propertyDes[i].length; j++){
                    List<Integer> list = map.get(i);
                    if(list==null ||(list!=null&&!list.contains(j))){
                        if("".equals(propertyDes[i][j])){
                            mergerNum++ ;
                            if(mergerNum != 0 && j == (propertyDes[i].length-1)){
                                sheet.addMergedRegion(new CellRangeAddress(i,i,j-mergerNum,j)); // 合并单元格
                                mergerNum = 0 ;
                            }
                        }else {
                            if(mergerNum != 0){
                                sheet.addMergedRegion(new CellRangeAddress(i,i,j-mergerNum-1,j-1)); // 合并单元格
                                mergerNum = 0 ;
                            }
                        }
                    }
                }
            }
        }

    展开全文
  • 导出Excel文件是业务中经常遇到的需求,以下是经常遇到的一些问题:1,导出中文文件名乱码String filename = "sheet1";response.setCharacterEncoding("UTF-8");response.setContentType("application/octet-stream...

    导出Excel文件是业务中经常遇到的需求,以下是经常遇到的一些问题:

    1,导出中文文件名乱码

    String filename = "sheet1";

    response.setCharacterEncoding("UTF-8");

    response.setContentType("application/octet-stream");

    response.setHeader("Content-Disposition","attachment;filename=" + URLEncoder.encode(filename, "UTF-8"));

    2,导出多个sheet怎么实现(map)

    private Map workbook = new LinkedHashMap();

    3,导出excel的表头是多级的怎么实现

    07223f34552ede8ad3dc8354c0b89069.png

    4,导出的sheet命名不规范报错

    4cca06bb7d2f45cda9e75ab1c3b8e73e.png

    public static String excelSheetName(String str) {

    if (StringUtils.isBlank(str)){

    str = String.valueOf(System.currentTimeMillis());

    }else {

    String regex = "(\\*|/|:|\\\\|\\[|\\]|\\?)";

    str = str.replaceAll(regex, "-");

    if (str.length() > EXCEL_SHEET_NAME_LENGTH) {

    str = str.substring(0, EXCEL_SHEET_NAME_LENGTH);

    }

    }

    return str;

    }

    展开全文
  • java导出excel多重表头

    2018-02-05 01:59:01
    后台代码对多重表头要怎么排列?比如星期一下面还有早上,中午晚上,再下面才是动态数据! ![图片说明](https://img-ask.csdn.net/upload/201802/05/1517795905_167671.png)
  • 根据前台表样已定义好的高级表格,而当前表格的HeaderColumn部份为高级分组,即多层分组列,将我们前所见即所得,点击导出按钮后,直接根据数据的逻辑,自动生成了多层组表的表头部份数据样式。 文件夹中附有源代码...
  • 今天这篇文章就是分享导出Excel表头或多表头的实现,目前实现方案仅支持2行表头场景。如有更复杂的3行表头、4行表头复杂需求可以自行实现。二、实现思路1.借助POI包实现表头的写入。每个表头其实就是一行,如果是...
  • Java实现Excel表头动态数据导出

    千次阅读 2020-07-23 13:05:12
    好久没时间写帖子了,由于工作需要,写一个基于JAVA实现的Excel表头动态导出功能,首先可能这个叫法比较啰嗦,下面我们先看看什么是Excel表头动态导出(效果图): 它包含两部分:1、是表头,就像大家看到的...
  • Java 导出多级表头

    2020-10-26 09:06:16
    --EasyPoi导入导出--> <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-base</artifactId> <version>3.0.3</version> </dependency> <...
  • 主要介绍了Java实现生成Excel树形表头完整代码示例,具有一定借鉴价值,需要的朋友可以参考下。
  • Java POI 导出excel ,多表头excel

    千次阅读 2018-07-11 17:41:30
    项目导出excel功能,在特定的项目中应该是很常见的。 本人也因需要使用,所以这两天就研究了一下,并做个记录。 这里先简单介绍一下导出excel的几种方法,如我标题所说,poi导出excel,所以这里不会讲和poi无关的...
  • java动态导出Excel功能工具类,含二级表头合并以及列合并 传参请仔细阅读开头注释,其中列合并功能其实还可以继续完善,目前只支持全列合并 代码如下: import com.common.util.common.StringUtil; import org....
  • poi导出excel复杂表头表格数据

    千次阅读 2019-09-19 18:44:20
    import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache....
  • 使用poi导出excel生成复杂多级表头通用方法 话不多说,直接上代码,需要用的的实体类如下 话不多说,直接上代码,需要用的的实体类如下 package com.test; public class UnioExcel { private Integer firstCol;//...
  • 做完二级表头导出,头昏脑涨,突生辞职冲动。因为一旦列位置不对,就得去茫茫码海里找哪里写错了。 于是,我绞尽脑汁封装了个工具类。 项目地址: github:https://github.com/lieyanfeimao/Po
  • POI实现导出多级表头和含有表尾部信息的excel

    千次阅读 热门讨论 2018-12-10 17:52:35
    最近由于业务需要,在做导出Excel的业务需求,要求导出的Excel含有多级表头,和含有表尾部数据,如下图的表格: 运用java的POI来实现上述需求: //表格头数组 String[][] names = {{"合作费审批单", "", "", ...
  •  如上excel表头要分组,第一行表头有值为大分类,第二行有值为中分类,第三行有值为小分类,第四行为具体分类。 例 第一行表头1的时候 <p>{1},{开始},{开始时间}&#...
  • import java.io.FileOutputStream; import java.io.OutputStream; import java.lang.reflect.Field; import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.UUID; ...
  • 额外添加的内容就是表格标题,理论上支持导出一级、二级、三级等多级表头Excel文档,测试一级、二级是OK的,先上效果图如下:   这是导出一级表头的Excel文档效果图:   这是导出二级表头的Excel文档效果图: ...
  • //表头1 要合并的格表头描述字段 已@分割 注意 这里的表头是至第一行表头 var gauge_head2="日期@交易量汇总@设备占比@WEB占比@APP占比@互生币支付@互商订单支付@代兑互生币@兑换互生币@货币转银行";// 表头描述...
  • Excel表格示例:  excel导出  填表单位:测试单位  20...
  • packageorg.jeecg.common....importjava.io.ByteArrayInputStream;importjava.io.ByteArrayOutputStream;importjava.io.OutputStream;importjava.text.DecimalFormat;importjava.text.SimpleDateFormat;importjava...
  • JAVA POI导出复杂表头Excel

    千次阅读 2019-08-24 13:49:42
    参考文章 https://blog.csdn.net/u013585096/article/details/83503519... 我的结果表格样式 //Excel HSSFWorkbook hssfWorkbook = new HSSFWorkbook(); Sheet sheet = hssfWorkbook.createSheet("sheet1"); ...

空空如也

空空如也

1 2 3 4 5 ... 15
收藏数 300
精华内容 120
关键字:

java导出excel多级表头

java 订阅