A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本帖最后由 小鲁哥哥 于 2020-1-8 18:59 编辑



jXLS是什么东东?
  • 官方介绍:jXLS is a small and easy-to-use Java library for writing Excel files using XLS templates and reading data from Excel into Java objects using XML configuration.
  • 哎呀这是什么呀,来点能看的懂的吧,这个大体的意思就是:jXLS是一个基于XML配置的小型,易于使用java类库,可以用来写Excel格式文档,也可以用来读取Excel格式文档中的数据。
  • 通俗的说,在java程序中,我们可以基于Excel的模板和最终Excel文档中显示的数据,使用jXLS完成Excel格式文档的生成。这就要求我们在java程序中完成以下几项内容:
    • 添加jXLS相关的jar包
    • 在java程序中准备好需要生成到Excel文档中的数据
    • 制作Excel格式的模板
    • 编写基于jXLS的代码,把Excel模板和数据整合,生成Excel格式文档
基本使用
  • 需求描述:把100名员工的信息(包含员工编号,员工姓名,员工性别,员工年龄,员工薪资)写入到Excel格式文档中。
  • 实现
    • 步骤一:创建一个maven工程,并添加依赖
    [Java] 纯文本查看 复制代码
    <dependencies>
                    <!-- jxls核心依赖 -->
                    <dependency>
                            <groupId>net.sf.jxls</groupId>
                            <artifactId>jxls-core</artifactId>
                            <version>1.0.6</version>
                    </dependency>
                    <!-- junit单元测试依赖 -->
                    <dependency>
                            <groupId>junit</groupId>
                            <artifactId>junit</artifactId>
                            <version>4.12</version>
                    </dependency>
                    <!-- 日志的依赖 -->
                    <dependency>
                            <groupId>org.slf4j</groupId>
                            <artifactId>slf4j-log4j12</artifactId>
                            <version>1.7.12</version>
                    </dependency>
            </dependencies>

    • 步骤二:编写员工信息实体类
    [Java] 纯文本查看 复制代码
    public class EmployeeInfo {
    
            private String empNo;//员工编号
            private String empName;//员工姓名
            private String empSex;//员工性别:1代表男,0代表女
            private Integer empAge;//员工年龄
            private Double empSalary;//员工薪资
            public String getEmpNo() {
                    return empNo;
            }
            public void setEmpNo(String empNo) {
                    this.empNo = empNo;
            }
            public String getEmpName() {
                    return empName;
            }
            public void setEmpName(String empName) {
                    this.empName = empName;
            }
            public String getEmpSex() {
                    return empSex;
            }
            public void setEmpSex(String empSex) {
                    this.empSex = empSex;
            }
            public Integer getEmpAge() {
                    return empAge;
            }
            public void setEmpAge(Integer empAge) {
                    this.empAge = empAge;
            }
            public Double getEmpSalary() {
                    return empSalary;
            }
            public void setEmpSalary(Double empSalary) {
                    this.empSalary = empSalary;
            }
    }

    • 步骤三:模拟查询数据库得到100名员工的信息
    [Java] 纯文本查看 复制代码
    public class EmployeeDao {
    
            /**
             * 模拟查询数据库得到100名员工的信息
             * @return :100名员工的信息
             */
            public List<EmployeeInfo> findEmployees(){
                    List<EmployeeInfo> list = new ArrayList<EmployeeInfo>();
                    
                    for(int i=1;i<=100;i++){
                            EmployeeInfo emp = new EmployeeInfo();
                            emp.setEmpNo(UUID.randomUUID().toString());//使用UUID生成随机
                            emp.setEmpName("员工姓名"+i);
                            emp.setEmpAge(new Random().nextInt(40));//随机生成年龄
                            emp.setEmpSex(i%2+"");//根据序号生成员工的性别
                            emp.setEmpSalary(new Random().nextDouble()*10000);//随机生成薪资
                            
                            list.add(emp);
                    }
                    
                    return list;
            }
    }

    • 步骤四:制作Excel文档模板,复制到程序中src目录下

           说明:在模板中使用jxls的表达式`<jx:forEach items="" var="" ></jx:forEach>`,js:forEach的作用类似于jstl中的c:forEach,用来遍历集合,items的值要和步骤五中的map集合中的key值一致,var值是每次遍历得到的元素,取元素中的值使用 ${元素的名称} 格式的表达式。
    • 步骤五:编写导出Excel文档的代码
    [Java] 纯文本查看 复制代码
    public class ExportExcel {
    
            public void expExcelWithJxls() throws Exception{
                    //1、获取导出文档中的数据,存放到一个Map集合中
                    EmployeeDao empDao = new EmployeeDao();
                    List<EmployeeInfo> employees = empDao.findEmployees();
                    Map<String,Object> map = new HashMap<String,Object>();
                    map.put("emps", employees);
                    
                    //2、使用ClassLoader读取模板
                    InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("emp_template.xlsx");
                    
                    //3、创建Excel文档转换器
                    XLSTransformer xlsTransformer = new XLSTransformer();
                    
                    //4、基于数据和模板,转换成Excel文档
                    //第一个参数是模板的输入流
                    //第二个参数是需要生成到文档中的数据
                    Workbook workbook = xlsTransformer.transformXLS(inputStream, map);
                    
                    //5、把Excel文档输出到指定位置
                    FileOutputStream outputStream =  new FileOutputStream("d:/jxls/empInfo.xlsx");
                    workbook.write(outputStream);
            }
    }

    • 步骤六:编写测试程序,测试导出员工信息的文档
    [Java] 纯文本查看 复制代码
    public class ExcelTest {
    
            @Test
            public void exportExcel(){
                    ExportExcel excel = new ExportExcel();
                    try {
                            excel.expExcelWithJxls();
                    } catch (Exception e) {
                            e.printStackTrace();
                            System.out.println("导出文档出现错误了,错误信息"+e.getMessage());
                    }
            }
    }
    
  • 导出Excel文档的效果

      
  • 其中存在问题
    • 问题描述:从导出的Excel文档的效果可以看出其中的性别显示的1或者0,而正常情况下应该显示男或者女,接下来就需要对此问题进行修复
    • 问题修复:使用jXLS提供的另一个指令<jx:if test=""></jx:if>,其作用是判断值,从而指定显示的内容
    • 修改后的模板
    • 生成Excel文档的效果

  • 需求变更:在生成Excel文档的同时,计算出员工薪资总金额,以及平均值
    • 若要完成该需求,只需要修改Excel模板,修改之后的模板
    • 生成Excel文档的效果



游客,如果您要查看本帖隐藏内容请回复


9 个回复

倒序浏览
支持支持!!!
回复 使用道具 举报
写的特别好,很详细,给力
回复 使用道具 举报
下载竟然还要回复点赞呢还是不点赞呢
回复 使用道具 举报
写的很好
回复 使用道具 举报
支持支持!!!
回复 使用道具 举报
支持支持!!
回复 使用道具 举报
看看!!!!
回复 使用道具 举报
小湖 初级黑马 2019-8-15 11:07:04
9#
你好,我的是使用模板导出Excel,循环是分开的两部分,但是后面部分表格式样就乱掉了,是怎么回事。
回复 使用道具 举报
膜拜大哥
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马