【Java】Jxls--轻松生成 Excel

1、介绍

Jxls 是一个小型 Java 库,可以轻松生成 Excel 报告。Jxls 在 Excel 模板中使用特殊标记来定义输出格式和数据布局。

Java 有一些用于创建 Excel 文件的库,例如Apache POI。这些库都很好,但都是一些较底层的库,因为它们要求开发人员编写大量 Java 代码,甚至创建一个简单的 Excel 文件。

通常,人们必须手动设置电子表格的每个单元格格式和数据。根据报表布局和数据格式的复杂性,Java 代码可能变得相当复杂并且难以调试和维护。此外,并非所有 Excel 功能都受支持并且可以使用库 API 进行操作(例如,对宏、图表等的支持有限)。

对于不支持的功能,建议的解决方法是在 Excel 模板中手动创建对象,然后使用数据填充模板。Jxls提供了这种功能。使用 Jxls 时,只需在 Excel 模板文件中定义所需的报告格式和数据布局,然后运行 ​​Jxls 引擎以使用数据填充模板。开发人员只需编写一点Java代码即可触发Jxls引擎对模板的处理。

2、入门示例

jxls底层是依赖poi。

引入对应的库:

xml 复制代码
	<dependency>
			<groupId>org.jxls</groupId>
			<artifactId>jxls</artifactId>
			<version>2.10.0</version>
		</dependency>

		<dependency>
			<groupId>org.jxls</groupId>
			<artifactId>jxls-poi</artifactId>
			<version>2.10.0</version>
		</dependency>

创建DTO:

Employee.java

java 复制代码
package com.example.demo;

import lombok.Data;

import java.math.BigDecimal;
import java.util.Date;

@Data
public class Employee {
    private String name;

    private Date birthDate;

    private BigDecimal payment;

    private BigDecimal bonus;
}

制作模板:

注意:
jx:area(lastCell="D5"):要模板的设置区域
jx:each(items="employees" var="employee" lastCell="D5"):设置填充数据时的表达式命令

测试代码:

java 复制代码
package com.example.demo;

import lombok.extern.slf4j.Slf4j;
import org.jxls.common.Context;
import org.jxls.util.JxlsHelper;

import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.math.BigDecimal;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;

@Slf4j
public class JxlsDemoMain {
    public static void main(String[] args) {
        log.info("start...");
        List<Employee> employeeList = generateEmployeeData();
        try(InputStream is =JxlsDemoMain.class.getResourceAsStream("/templates/demo.xls");
       OutputStream os = new FileOutputStream("demo-001.xls")){
            Context context = new Context();
            context.putVar("employees",employeeList);
            JxlsHelper.getInstance().processTemplateAtCell(is,os,context,"Result!A1");

        }catch (Exception e){
            e.printStackTrace();
            log.error(e.getMessage());
        }

    }

    private static List<Employee> generateEmployeeData(){
        List<Employee> employees = new LinkedList<>();

        int num = 100;
        while (num>0){
            Employee employee = new Employee();
            employee.setName("kexuexiong"+num);
            employee.setBonus(BigDecimal.valueOf(1000));
            employee.setPayment(BigDecimal.valueOf(1000));
            employee.setBirthDate(new Date());
            employees.add(employee);
            num--;
        }

        return employees;
    }

}

输出结果:

相关推荐
nangonghen1 分钟前
JAVA程序实现mysql读写分离并在kubernetes中演示
java·mysql·mybatis·读写分离
ghost1434 分钟前
Python自学第1天:变量,打印,类型转化
开发语言·python·学习
depend4 分钟前
用 AI 实现一个 GBK/GB2312 转 UTF-8 工具:轻松解决文本编码转换难题(附完整源码)
python
eternal__day6 分钟前
MyBatis-Plus 详解:快速上手到深入理解
java·spring boot·后端·spring·java-ee·maven·mybatis
Java中文社群19 分钟前
超实用!用FunctionCall实现快递AI助手
java·人工智能·后端
XuanXu20 分钟前
Java Project Leyden如何提高JVM启动速度&技术前瞻
java
人猿泰飞23 分钟前
在Ubuntu-22.04.5中安装ONLYOFFICE DocSpace(协作空间)【注意:安装失败,谨慎参考!】
java·linux·运维·python·ubuntu·项目管理·onlyoffice
Enougme29 分钟前
python-将文本生成音频
python·音视频·语音识别
愿你天黑有灯下雨有伞29 分钟前
MyBatis与MyBatis-Plus:字段自动填充的两种实现方式
java·mybatis
程序员黄老师34 分钟前
MyBatis 中 Mapper 传递参数的多种方法
java·tomcat·mybatis