zoukankan      html  css  js  c++  java
  • jxl导入/导出Excel(Maven)

    jxl && POI
    jxl是一个开源的Java Excel API项目,通过Jxl,Java可以很方便的操作微软的Excel文档。除了Jxl之外,还有Apache的一个POI项目,也可以操作Excel,两者相比之下:Jxl使用方便,但功能相对POI比较弱,很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告。有时,一个应用程序甚至希望将Excel文件作为输入数据。例如,一个公司开发的应用程序将财务部门需要所有输出生成自己的Excel。
    Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件。这由Apache软件基金会开发使用Java分布式设计或修改Microsoft Office文件的开源库。它包含类和方法对用户输入数据或文件到MS Office文档进行解码。

    使用jxl导出excel

    使用jxl导出Excel 首先先在pom.xml添加依赖

         <!--jxl-->
        <dependency>
            <groupId>net.sourceforge.jexcelapi</groupId>
            <artifactId>jxl</artifactId>
            <version>2.6.12</version>
        </dependency>                    

    前台界面

    我们现在需要在页面上点击导出Excel按钮就可以把表格导出来

     接着需要在js文件实现exportFile函数

       /*导出文件*/
        exportFile: function () {
            window.location.href = "/underwrite_export.do"
        },

    后台业务

    这时js会跳转到url:underwrite_export.do
    这时浏览器会根据域名查找 Spring会根据映射的url在Controller执行对应的方法

    //==========导出Excel===========
    @PermissionName("核保审核结果导出")
    @RequestMapping("/underwrite_export")
    @RequiresPermissions("underwrite:export")
    @ResponseBody
    public void exportFile(HttpServletResponse response) throws Exception {
        // 1.文件下载响应头
        response.setHeader("Content-Disposition", "attachment;filename=underwrite.xls");
        // 2.响应到浏览器
        WritableWorkbook workbook = Workbook.createWorkbook(response.getOutputStream());
        // 创建工作簿sheet
        WritableSheet sheet = workbook.createSheet("underwrite", 0);
        // 3.设置column名
        sheet.addCell(new Label(0, 0, "承保机构"));
        sheet.addCell(new Label(1, 0, "申请单号"));
        sheet.addCell(new Label(2, 0, "产品名称"));
        sheet.addCell(new Label(3, 0, "投保人"));
        sheet.addCell(new Label(4, 0, "申请时间"));
        sheet.addCell(new Label(5, 0, "提交员工"));
        sheet.addCell(new Label(6, 0, "提交状态"));
        sheet.addCell(new Label(7, 0, "审核状态"));
        sheet.addCell(new Label(8, 0, "额度"));
        // 4.把核保的数据填充到工作簿中 service调用selectExport()查询数据库
        List<UnderwriteWait> list = service.selectExport();
        System.out.println(list.toArray());
        try{
        for (int i = 0, j = 1; i < list.size(); i++, j++) {
            UnderwriteWait underwrite = list.get(i);
            //System.out.println(underwrite);
           //设置列宽
            sheet.setColumnView(i, 16);
            //重新设置部分列宽
            sheet.setColumnView(3, 14);
            sheet.setColumnView(6, 10);
            sheet.setColumnView(7, 10);
            //设置行高
            sheet.setRowView(i, 350);
            //设置字体的attribute
            WritableFont font1=new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD);
            WritableCellFormat format1=new WritableCellFormat(font1);
            System.out.println(underwrite.getId());
            sheet.addCell(new Label(0, j, underwrite.getOrg().getName(),format1));
            sheet.addCell(new Label(1, j, underwrite.getApplyordernumber(),format1));
            sheet.addCell(new Label(2, j, underwrite.getCarinsuranc().getInsName(),format1));
            sheet.addCell(new Label(3, j, underwrite.getClient().getName(),format1));
            String applydate=underwrite.getApplydate().toLocaleString().substring(0,9);
            sheet.addCell(new Label(4, j, applydate,format1));
            sheet.addCell(new Label(5, j, underwrite.getEmployee().getRealname(),format1));
            String stateApply=(underwrite.getStateApply().toString().equals("0")) ? "未审核":"已提交";
            sheet.addCell(new Label(6, j,stateApply));
            String stateAudit=(underwrite.getStateAudit().toString().equals("1")) ? "已提交":"已审核";
            sheet.addCell(new Label(7, j, stateAudit));
            sheet.addCell(new Label(8, j, underwrite.getAmount().toString(),format1));
        }}catch (Exception e){
            e.printStackTrace();
        }
        // 5.写入数据
        workbook.write();
        // 6.关闭资源
        workbook.close();
    }

     

    这时我们就把jxl导出excel的功能做完了

    jxl导入Excel

    js文件

    /*导入文件*/
        importFile: function () {
            /*清空表单*/
            $("#underwrite_file").form("clear");
            /*打开弹出框*/
            $("#underwrite_file").dialog("open");
        }

    后台Controller

    @PermissionName("资料导入")
    @RequestMapping("/underwrite_import")
    @RequiresPermissions("underwrite:import")
    public String importFile(MultipartFile file) throws Exception {
        // 1.获取用户上传的文件
        Workbook workbook = Workbook.getWorkbook(file.getInputStream());
        // 2.获取工作簿sheet
        Sheet sheet = workbook.getSheet(0);
        // 3.获取总行数
        int rows = sheet.getRows();
        for (int i = 1; i < rows; i++) {
            Underwrite underwrite = new Underwrite();
            underwrite.setXxx(sheet.getCell(0, i).getContents());
            underwrite.setXxx(sheet.getCell(1, i).getContents());
            employee.setXxx(sheet.getCell(2, i).getContents());
            employee.setEmail(sheet.getCell(3, i).getContents());
            // 4.添加到数据库中
            service.insert(underwrite);
        }
        // 5.关闭资源
        workbook.close();
        return "underwrite";
    }

    参考:WritableWorkbook 详细用例

             jxl 与poi 操作Excel区别

  • 相关阅读:
    疯狂Java讲义 读书笔记(一)
    Android5.0开发范例大全 读书笔记(六)
    Android5.0开发范例大全 读书笔记(五)
    Android5.0开发范例大全 读书笔记(四)
    Android5.0开发范例大全 读书笔记(三)
    Android5.0开发范例大全 读书笔记(二)
    Android5.0开发范例大全 读书笔记(一)
    Java基础总结(三)
    Java基础总结(二)
    Java基础总结(一)
  • 原文地址:https://www.cnblogs.com/zouhong/p/13553165.html
Copyright © 2011-2022 走看看