使用XLSTransformer生成报表的步骤和流程

article/2025/11/5 3:14:16


使用XLSTransformer生成XLS报表的步骤和流程:


需要引入的jar包:

jxls-core-0.9.7.jar

jxls-reader-0.9.7.jar

poi-3.6.jar

commons-jexl-1.1.jar

commons-digester-2.0.jar

commons-beanutil-core-1.8.3.jar

commons-collection.jar


示例代码:

import java.io.IOException;  
import java.net.URL;  
import java.util.HashMap;  
import java.util.List;  
import java.util.Map;  
import net.sf.jxls.exception.ParsePropertyException;  
import net.sf.jxls.transformer.XLSTransformer;  

1,查询数据库记录,获得需要导出到execl中的数据;
2,把数据封装到List中; 

通常我们是这样做的:List<Object> business = new ArrayList<Object>();


3,将List放到HashMap中;

通常我们是这样做的:

Map<String, Object> beans = new HashMap<String, Object>();

business.add(businessCharge);


4,xls模板文件路径;   //这个需要开发者提供,放在项目的某个目录下

我们如果需要生成execl报表文件,需要先设置好一个报表模板,如下图所示:



说明:

    a,<jx:forEach items="$Entity" var="entity"></jx:forEach>,迭代标签,迭代输出所有的记录;

    b,Entity = 封装记录的对象,如果是单表查询,就是实体类;如果是多表查询,就是封装查询结果的对象,可以看作是一个新的实体类。

    c,entity = 别名

    d,entity.id = 实体类中的id字段


5,生成的目标文件路径; //目标文件路径:可以是本地的E盘上等等


6,创建目标文件夹;FileUtil.makeDir(“生成的目标报表的路径,注意,这里没有文件名”);

if(!FileUtil.isFileExists("目标文件路径 + 目标文件名称")){FileUtil.makeDir("目标文件路径");	
}

7,创建XLSTransformer 对象,调用transformer.transformXLS(templatePath, beans, reportPath),生成报表。

以上就是使用XLSTransformer生成报表的大概流程。难点在于数据的获取,例如些SQL语句,检查获得的报表的数据的完整性,准确性,安全性等。生成报表使用的最多的就是存储过程了,所以掌握生成报表的技术,我们需要先掌握存储过程的知识。


如果需要生成TXT报表,则可以这样进行:

/***  生成txt报表/txt报表 */
public void generateTxtReport() {String reportDate = "2016-03-05";Map<String, Object> map = new HashMap<String, Object>();map.put("reportDate", reportDate);BigDecimal payAmtCount = new BigDecimal(0);String reportPath = "report.txt";PrintWriter printWriter = null;try {printWriter = new PrintWriter(reportPath, "GBK");printWriter.printf("%-32s\r\n", "XXX明细报表(TXT)");// 查询报表数据List<Map<String, Object>> Entitylist = null; //从数据库查询出来的数据可以直接封装在这个list中 EntitylistList<Map<String, Object>> listNew;BigDecimal payAmtVendorCount;for (Map<String, Object> EntityInfo : Entitylist) {map.put("Id", EntityInfo.get("ID"));listNew = null; //从数据库中查询出来的数据// 输出数据到TXT报表if (!listNew.isEmpty()) {printWriter.printf("%-50s\r\n", EntityInfo.get("ID"));printWriter.printf("%-100s\r\n", EntityInfo.get("NAME"));printWriter.printf("总金额");// 表头printWriter.printf("%-150s\r\n","-----------------------------------------------------------");payAmtCount = new BigDecimal(0);for (Map<String, Object> value : listNew) {payAmtCount = payAmtVendorCount.add((BigDecimal) value.get(AMT));// 循环统计商户数据payAmtCount = payAmtCount.add((BigDecimal) value.get(AMT));// 打印数据printWriter.printf("XXXX");}// 单个商户合计打印printWriter.printf("%-150s\r\n","-----------------------------------------------------------");printWriter.printf("%-20s%\r\n", "合计:", "交易笔数:" + listNew.size(), "", payAmtCount);printWriter.printf("%1s\r\n", " ");// 空行try {printWriter.flush();} catch (Exception e) {}}}printWriter.printf("%-50s\r\n", "总合计:");printWriter.printf("%-15s\r\n", "-----------------------------------------------------------");printWriter.printf("%-10s%\r\n", "总交易笔数");printWriter.printf("%-15s%\r\n", payAmtCount);printWriter.printf("%-15s\r\n", "-----------------------------------------------------------");} catch (Exception e) {log.error("Export txt fail", e);} finally {try {printWriter.flush();printWriter.close();} catch (Exception e) {log.error("IO txt fail", e);}}
}

接着会继续分享报表方面的经验。




http://chatgpt.dhexx.cn/article/g6I7YQyE.shtml

相关文章

利用模板导出文件(一)之XLSTransformer导出excel文件

由于现在好多公司都在实行办公无纸化操作&#xff0c;所以一般都是使用excel以及word来办公&#xff0c;本文是公司项目中使用excel文件模板生成对应的文件&#xff1a; 首先&#xff0c;需要导入一下几个包&#xff1a; 接下来就是具体的代码&#xff1a; import java.io.Fil…

关于使用XLSTransformer.transformXLS导出Excel表格中遇到的问题

1. 需求&#xff1a;最近拿到的一个任务&#xff0c;是将订单列表导出&#xff0c;按照订单列表导出&#xff08;包括筛选条件&#xff09;。 背景&#xff1a;由于原本的订单列表查询代码太过繁重&#xff0c;里面夹杂的逻辑较多&#xff0c;再有一个是自己想尽快的熟悉公司…

最简单方便的excel导出方式

前言&#xff1a;开发各种统计系统以及报表系统之类的不可避免的就是导出excel功能&#xff0c;传统的poi用过的都知道&#xff0c;每个sheet每个row都需要去定义去美化&#xff0c;繁琐不说还很浪费时间&#xff0c;最近本人发现两种较快速的方法&#xff0c;一种是excel模版方…

Handler、Looper、HandleThread、ActivityThread简介

1. Handler 源码位于&#xff1a; platform/frameworks/base/core/java/android/os/Handler.java Handler允许发送和处理与线程的MessageQueue关联的Message和Runnable对象。每个Handler实例都与单个线程和该线程的消息队列相关联。 当创建一个新的Handler时&#xff0c;它会被…

Android—ActivityThread与Handler

应用启动过程&#xff1a; ActivityThread ActivityThread就是主线程或UI线程&#xff0c;ActivityThread的main方法是整个APP的入口。 public final class ActivityThread {//... final H mH new H();final ArrayMap<IBinder, ActivityClientRecord> mActivities n…

ActivityThread运行框架

http://www.embeddedlinux.org.cn/Androidkernel/77.htm 在分析中&#xff0c;我们可以看到真正对应应用进程的不是Application而是ActivityThread。我们从实际的应用堆栈可以看到&#xff1a; NaiveStart.main() ZygoteInit.main ZygoteInit$MethodAndArgsCall.run Method.In…

ActivityThread应用进程

ActivityThread应用进程 android12-release Zygote进程SystemServer进程(即system_server)Launcher启动过程、AMS:startActivity桌面启动应用 缺少具体应用进程启动 1. 涉及进程 Zygote进程&#xff1a;init进程 fork 第一个Java进程&#xff0c;Zygote是所有Java进程的父进…

Android-Activity

配置Activity&#xff1a; 如果Activity所在的包与AndroidManifest.xml文件的<manifest></manifest>标签中通过 package属性指定的包名一致&#xff0c;则android:name属性的值可以直接设置为“.Activity名称” <activity android:name"…

ActivityThread的main方法究竟做了什么?

ActivityThread的main方法究竟做了什么&#xff1f; 本文原创&#xff0c;转载请经过本人准许。 写在前面&#xff1a; 在暴雨天能去上课的都是好学生&#xff0c;能去上班的都是游泳运动员~ 问大家一个问题&#xff1a; Android中一个应用程序的真正入口是什么&#xff1f; …

Android Activity.startActivity流程简介

1. 基本概念 1.1 Instrumentation是什么? 顾名思义&#xff0c;仪器仪表&#xff0c;用于在应用程序中进行“测量”和“管理”工作。一个应用程序中只有一个Instrumentation实例对象&#xff0c;且每个Activity都有此对象的引用。Instrumentation将在任何应用程序运行前初始化…

android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity context

问题描述 FATAL EXCEPTION: main Process: com.wuchen.juexiao_mvvm, PID: 11732 android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity context requires the FLAG_ACTIVITY_NEW_TASK flag. Is this really what you want? 原因分析…

Android主线程(ActivityThread)源代码分析

在写这篇博客之前,先抛出一个问题&#xff0c;安卓应用程序的入口是什么呢&#xff1f;我想不少人可能回答说:application的onCreate方法&#xff0c;其实并不是的&#xff0c;即使是application&#xff0c;也有一个方法比onCreate先执行&#xff0c;这个方法就是attachBaseCo…

Android :Activity

Activity Activity 代表手机或平板电脑中的一屏&#xff0c;它提供了和用户交互的可视化界面。 一个 Android 应用中&#xff0c;可以有多个 Activity。这些 Activity 组成了 Activity 栈&#xff08;Stack&#xff09;&#xff0c;当前活动的 Activity 位于栈顶。 Activity …

ActivityThread

ActivityThread运行框架 在分析中&#xff0c;我们可以看到真正对应应用进程的不是Application而是ActivityThread。我们从实际的应用堆栈可以看到&#xff1a; NaiveStart.main() ZygoteInit.main ZygoteInit$MethodAndArgsCall.run Method.Invoke method.invokeNative Activi…

【Android 启动过程】Activity 启动源码分析 ( AMS -> ActivityThread、AMS 线程阶段 )

文章目录 一、Activity 启动源码分析 ( AMS | ActivityManagerService )1、Instrumentation 调用 AMS 方法2、ActivityStarter 调用 AMS 方法3、Process 启动新进程 二、Activity 启动源码分析 ( ActivityStarter )1、ActivityStarter.startActivityMayWait() 方法2、ActivityS…

Android 中你碰不到但是很重要的类之ActivityThread

作者&#xff1a;Drummor 通过本文能了解一下内容 1、和系统进程打交道的桥头堡 应用进程起来之后ART(Android Runtime)第一站就是ActivityThread&#xff0c;代码层面上就是ActivityThread的main()方法&#xff0c;是不是很熟悉&#xff0c;爷青回啊&#xff0c;这不就是java…

浅析ActivityThread#main()方法和生命周期事务处理(代码基于Android-12)

浅析ActivityThread#main()方法和生命周期事务处理&#xff08;代码基于Android-12&#xff09; 问题&#xff1a; Activity、Application的onCreate()在哪被调用的&#xff1f; ContentProvider为什么比Application先创建&#xff1f; Activity#attach()在哪里被调用的&#…

Android中的ActivityThread和ApplicationThread

一&#xff1a;ActivityThread和ApplicationThread 1.ActivityThread&#xff1a;主线程、UI线程&#xff0c;程序的入口&#xff08;main函数&#xff09;&#xff0c;不是线程是运行在主线程中的一个对象 主要的成员变量如下&#xff1a; mActivities、mServices和mProvide…

一文读懂ActivityThread

ActivityThread是什么&#xff0c;是主线程吗&#xff1f;它是如何被创建的&#xff0c;以及它的作用又是什么呢&#xff1f;带着这些问题&#xff0c;我们一起来分析下ActivityThread。 全文分为以下几个部分&#xff0c;大家可根据需求阅读 文章目录 ActivityThread是什么Act…

Android ActivityThread(主线程或UI线程)简介

1. ActivityThread功能 它管理应用进程的主线程的执行(相当于普通Java程序的main入口函数)&#xff0c;并根据AMS的要求&#xff08;通过IApplicationThread接口&#xff0c;AMS为Client、ActivityThread.ApplicationThread为Server&#xff09;负责调度和执行activities、broa…