1.pom.xml中加入poi依赖:

  <!-- poi -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.10-FINAL</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.10-FINAL</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-scratchpad</artifactId>
            <version>3.10-FINAL</version>
            <type>jar</type>
            <scope>compile</scope>
        </dependency>

2.创建导出excel文件模板;

3.controller层实现代码:

 @PostMapping("/excelCarrierOrder")
    public ResponseEntity<Resource> excelCarrierOrder(@RequestBody Map<String,Object> params,HttpServletResponse response) throws IOException{

    //列表数据
         XSSFWorkbook workbook = carrierOrderService.excelCarrierOrder(params);
         ByteArrayOutputStream os = new ByteArrayOutputStream();
         workbook.write(os);
         response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate");
         response.setHeader("Pragma", "no-cache");
         response.setHeader("Expires", "0");
         response.setHeader("charset", "utf-8");
         // 当前日期,用于导出文件名称
         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
         String name =sdf.format(new Date()) + ".xlsx";
         response.setHeader("Content-Disposition", "attachment;filename=\"" + URLEncoder.encode(name, "UTF-8") + "\"");
         workbook.write(response.getOutputStream());
         if (null != os) {
             os.close();
         }
         return new ResponseEntity<Resource>(null, null, HttpStatus.OK);
    }

4.service实现类实现代码:

@Override
    public XSSFWorkbook excelCarrierOrder(Map<String, Object> params) throws IOException {

   //模板路径
        String path = "/templates/excel/订单列表.xlsx";
        XSSFWorkbook workboot = new XSSFWorkbook(this.getClass().getResourceAsStream(path));
        //sheet页(默认sheet1页),也可通过workboot.createSheet("订单列表")创建sheet页
        XSSFSheet sheetAt = workboot.getSheetAt(0);
        //订单基本表数据
        List<CarrierOrderPojo> list = mapper.getExcelCarrierOrder(params);

   //开始创建行和表格并且加入数据
        //行
        XSSFRow row;
        int i = 0;
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm");
        if(null != list && !list.isEmpty()) {
            for (CarrierOrderPojo dto : list) {
                //根据订单id查询车辆信息
                List<CarrierOrderTruck> truckList = truckMapper.getTruckList(dto.getId());
                //根据订单id查询装卸车费用
                List<CarrierOrderServe> serveList = serveMapper.getServeList(dto.getId());
                //根据订单id查询采购详情
                List<CarrierOrderDetail> detailList = detailMapper.getCarrierOrderDetailList(dto.getId());
                String purchaseOrderNumber = "";
                i += 1;
                //创建行
                row = sheetAt.createRow(i);
                //承运商
                if(null != dto.getCarrierName()) {
                    row.createCell(0).setCellValue(dto.getCarrierName());
                }else {
                    row.createCell(0).setCellValue("");
                }
                //物流单号
                if(null != dto.getLogisticsNumber()) {
                    row.createCell(1).setCellValue(dto.getLogisticsNumber());
                }else {
                    row.createCell(1).setCellValue("");
                }
                //采购单号
                if(null != detailList && !detailList.isEmpty()) {
                    for (CarrierOrderDetail detaildto : detailList) {
                        purchaseOrderNumber += detaildto.getPurchaseOrderNumber()+",";
                    }
                    row.createCell(2).setCellValue(purchaseOrderNumber.substring(0, purchaseOrderNumber.length()-1));
                }else {
                    row.createCell(2).setCellValue("");
                }
                //发货时间
                if(null != dto.getTakingDate()) {
                    row.createCell(3).setCellValue(sdf.format(dto.getTakingDate()));
                }else {
                    row.createCell(3).setCellValue("");
                }
                //到货时间
                if(null != dto.getDeliveryDate()) {
                    row.createCell(4).setCellValue(sdf.format(dto.getDeliveryDate()));
                }else {
                    row.createCell(4).setCellValue("");
                }
                //总体积
                if(null != dto.getTotalAllVolume()) {
                    row.createCell(5).setCellValue(dto.getTotalAllVolume()+"m³");
                }else {
                    row.createCell(5).setCellValue("");
                }
                //箱型
                if(null != truckList && !truckList.isEmpty()) {
                    for (CarrierOrderTruck truckdto : truckList) {
                        if("面包车".equals(truckdto.getTruckType())) {
                            row.createCell(6).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("金杯车".equals(truckdto.getTruckType())){
                            row.createCell(7).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("2米7平板".equals(truckdto.getTruckType())){
                            row.createCell(8).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("3米8平板".equals(truckdto.getTruckType())){
                            row.createCell(9).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("4米2平板".equals(truckdto.getTruckType())){
                            row.createCell(10).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("4米2厢车".equals(truckdto.getTruckType())){
                            row.createCell(11).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("4米2高栏".equals(truckdto.getTruckType())){
                            row.createCell(12).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("6米8厢车".equals(truckdto.getTruckType())){
                            row.createCell(13).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("6米8高栏".equals(truckdto.getTruckType())){
                            row.createCell(14).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("7米6厢车".equals(truckdto.getTruckType())){
                            row.createCell(15).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("9米6厢车".equals(truckdto.getTruckType())){
                            row.createCell(16).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("9米6高栏".equals(truckdto.getTruckType())){
                            row.createCell(17).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("12米5厢车".equals(truckdto.getTruckType())){
                            row.createCell(18).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("13米高栏".equals(truckdto.getTruckType())){
                            row.createCell(19).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("16米5厢车".equals(truckdto.getTruckType())){
                            row.createCell(20).setCellValue(truckdto.getTruckNumber()+"辆");
                        }else if("17米5厢车".equals(truckdto.getTruckType())){
                            row.createCell(21).setCellValue(truckdto.getTruckNumber()+"辆");
                        }
                    }
                }
                //送货距离
                if(null != dto.getDistance()) {
                    row.createCell(22).setCellValue(dto.getDistance()+"km");
                }else {
                    row.createCell(22).setCellValue("");
                }
                //运输费用
                if(null != dto.getFreight()) {
                    row.createCell(23).setCellValue(dto.getFreight()+"元");
                }else {
                    row.createCell(23).setCellValue("");
                }
                //装货费用,卸货费用
                if(null != serveList && !serveList.isEmpty()) {
                    for (CarrierOrderServe servedto : serveList) {
                        if("装货".equals(servedto.getServiceType())) {
                            row.createCell(24).setCellValue(servedto.getPrice()+"元");
                        }else if("卸货".equals(servedto.getServiceType())){
                            row.createCell(25).setCellValue(servedto.getPrice()+"元");
                        }
                    }
                }
                //异常费用
                if(null != dto.getOtherCost()) {
                    row.createCell(26).setCellValue(dto.getOtherCost()+"元");
                }else {
                    row.createCell(26).setCellValue("");
                }
                //合计
                if(null != dto.getTotalCost()) {
                    row.createCell(27).setCellValue(dto.getTotalCost()+"元");
                }else {
                    row.createCell(27).setCellValue("");
                }
                //备注
                if(null != dto.getCarrierRemark()) {
                    row.createCell(28).setCellValue(dto.getCarrierRemark());
                }else {
                    row.createCell(28).setCellValue("");
                }
            }
        }
        return workboot;
    }

5.项目中引入第2步创建的模板,要与Service实现类中path路径对应:

6.效果:

7.XSSFWorkbook 做导出也可以不引入模板,通过workboot.createSheet("订单列表")创建sheet页,并设定表格样式,可实现相同的效果。但是我觉得导入模板比较简单,容易上手。

 如有错误,请指出,谢谢!

XSSFWorkbook实现导出excel的更多相关文章

  1. 关于poi导出excel方式HSSFWorkbook(xls).XSSFWorkbook(xlsx).SXSSFWorkbook.csv的总结

    1.HSSFWorkbook(xls) import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermo ...

  2. .net使用NPOI的XSSFWorkbook进行web开发中导出Excel

    之前也使用过NPOI导出excel,这次是因为在导出的excel里新增了几个列,正好超出了255的限制,所以又要改了. 今天主要出了4个问题: 1. Invalid column index (256 ...

  3. JAVA POI XSSFWorkbook导出扩展名为xlsx的Excel,附带weblogic 项目导出Excel文件错误的解决方案

    现在很多系统都有导出excel的功能,总结一下自己之前写的,希望能帮到其他人,这里我用的是XSSFWorkbook,我们项目在winsang 用的Tomcat,LInux上用的weblogic服务器, ...

  4. Java导出excel

    一.介绍 常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际的开发中,很多时候需要实现导入.导出Excel的应用. ...

  5. 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续篇)

    上周六我发表的文章<分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility>受到了大家的热烈支持与推荐,再此表示感谢,该ExcelUtility ...

  6. C# NPOI导出Excel和EPPlus导出Excel比较

    系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http: ...

  7. ASP.NET MVC导出excel(数据量大,非常耗时的,异步导出)

    要在ASP.NET MVC站点上做excel导出功能,但是要导出的excel文件比较大,有几十M,所以导出比较费时,为了不影响对界面的其它操作,我就采用异步的方式,后台开辟一个线程将excel导出到指 ...

  8. .NET NPOI导出Excel详解

    NPOI,顾名思义,就是POI的.NET版本.那POI又是什么呢?POI是一套用Java写成的库,能够帮助开发者在没有安装微软Office的情况下读写Office的文件. 支持的文件格式包括xls, ...

  9. Java POI导入导出Excel

    1.异常java.lang.NoClassDefFoundError: org/apache/poi/UnsupportedFileFormatException 解决方法: 使用的poi的相关jar ...

随机推荐

  1. 解决Tomcat 一闪而过的问题

    启动tomcat时cmd窗口一闪而过解决方法. 问题现象: 在实际开发中一般都是eclipse+tomcat(也许还会用到tomcat的插件),我们只需要在eclipse中单击servers上的按钮就 ...

  2. Sqlserver中查找包含某一列的所有的表

    select cols.name,cols.id,objs.name,objs.id from syscolumns cols INNER JOIN sysobjects objs on cols.i ...

  3. 浅谈Trigger

  4. 微信小程序开发注意点和坑集

    开发(Tips)   避开频繁setData * 小程序端对于频繁的逻辑层和显示层的交互很不友好,特别是安卓机,与浏览器上js直接操作DOM不同,小程序通过逻辑更新显示层并不完全实时,开发者应避免出现 ...

  5. 用Box2d物理引擎设计类似愤怒小鸟投篮游戏 物理引擎的引入和基本框架搭建

  6. 377. Combination Sum IV 返回符合目标和的组数

    [抄题]: Given an integer array with all positive numbers and no duplicates, find the number of possibl ...

  7. 270. Closest Binary Search Tree Value 二叉搜索树中,距离目标值最近的节点

    [抄题]: Given a non-empty binary search tree and a target value, find the value in the BST that is clo ...

  8. code1068 乌龟棋

    暴力显然不行,所以考虑dp 记f[i][j][k][l]为使用i张1,j张2,k张3,l张4所得到的最大分数. 对于每个f[i][j][k][l],都可以由i-1张1,j张2,k张3,l张4所得到, ...

  9. Python 序列与映射的解包操作-乾颐堂

    解包就是把序列或映射中每个元素单独提取出来,序列解包的一种简单用法就是把首个或前几个元素与后面几个元素分别提取出来,例如: first, seconde, *rest = sequence 如果seq ...

  10. 如何优雅地使用命令行设置windows文件关联

    如何优雅地使用命令行设置windows文件关联 使用ftype查看帮助 设置关联所需命令有ftype assoc,需要管理员权限.如果忘记使用方法可通过ftype的帮助获取查看方法 C:\WINDOW ...