0

0

在Java里实现基础报表生成功能_Java字符串拼接项目说明

P粉602998670

P粉602998670

发布时间:2025-12-30 18:14:17

|

348人浏览过

|

来源于php中文网

原创

用 StringBuilder 拼接 HTML 表格最稳,需预估容量、分离固定结构、仅最后调用 toString();用户输入须 HTML 转义防 XSS;金额用 DecimalFormat 显式指定 US Locale 格式化;CSV 导出应使用 OpenCSV 或 Commons CSV 库并添加 UTF-8 BOM。

在java里实现基础报表生成功能_java字符串拼接项目说明

StringBuilder 拼接报表 HTML 表格最稳

直接用 + 拼接多行 HTML 报表字符串,在循环中极易触发频繁对象创建,导致 GC 压力大、生成慢。尤其当数据量超 500 行时,String 拼接耗时可能翻倍。

实操建议:

  • 初始化 StringBuilder 时预估容量,比如每行约 120 字符 × 1000 行 → 设为 new StringBuilder(120_000)
  • 表格头、分页信息、合计行等固定结构,单独拼一次,别塞进主循环
  • 避免在循环内调用 toString(),只在最后生成完成时调用一次
StringBuilder report = new StringBuilder(120_000);
report.append("<table border=\"1\">\n<thead><tr><th>ID</th><th>姓名</th><th>金额</th></tr></thead>\n<tbody>\n");
for (Order order : orders) {
    report.append("<tr><td>")
          .append(order.getId())
          .append("</td><td>")
          .append(escapeHtml(order.getName())) // 防 XSS,见下节
          .append("</td><td>")
          .append(String.format("%.2f", order.getAmount()))
          .append("</td></tr>\n");
}
report.append("</tbody></table>");
String html = report.toString(); // 仅此处 toString()

必须对用户输入做 HTML 转义,否则会崩报表页面

报表字段若含 <&" 等字符(比如姓名是 "张三<研发部>"),不转义会导致 HTML 结构错乱,甚至执行脚本。

不要自己写正则替换 —— 容易漏掉 ' 或 Unicode 变体。用成熟工具更可靠:

立即学习Java免费学习笔记(深入)”;

  • JDK 9+ 可用 StringEscapeUtils.escapeHtml4()(来自 Apache Commons Text)
  • 若项目已引入 Spring,优先用 org.springframework.web.util.HtmlUtils.htmlEscape()
  • 纯 JDK 方案:手写一个最小化方法,只处理 4 个关键字符,比正则快且确定
private static String escapeHtml(String s) {
    if (s == null) return "";
    return s.replace("&", "&")
            .replace("<", "<")
            .replace(">", ">")
            .replace("\"", """);
}

DecimalFormat 格式化金额比 String.format 更可控

报表里金额字段要求统一显示为“千分位 + 两位小数”,比如 1234567.891,234,567.89。用 String.format("%,.2f", d) 看似简单,但受 Locale 影响大:在德国环境会输出 1.234.567,89,和中文报表预期不符。

Onlook
Onlook

专为前端设计师和开发者打造的视觉编辑工具

下载

实操建议:

  • 显式指定 Locale.US,或直接用 DecimalFormat 控制符号
  • 复用 DecimalFormat 实例(线程安全),避免每次 new
  • 注意 Double.NaNInfinity 会抛异常,需提前判空
private static final DecimalFormat AMOUNT_FORMAT = new DecimalFormat("#,##0.00");
static {
    AMOUNT_FORMAT.setDecimalFormatSymbols(new DecimalFormatSymbols(Locale.US));
}

// 使用时:
String amtStr = AMOUNT_FORMAT.format(order.getAmount());

导出 CSV 时别用字符串拼接,用 OpenCSV 或 Apache Commons CSV

报表常需同时支持 HTML 和 CSV 导出。用 StringBuilder 手拼 CSV 很危险:字段含逗号、换行、双引号时,必须按 RFC 4180 规则加引号并转义,手写极易出错(比如漏转义嵌套双引号 "a""b")。

直接上轻量库更省心:

  • OpenCSV:API 直观,CsvWriter 支持自动转义,适合单线程导出
  • Apache Commons CSV:更现代,支持流式写入、自定义分隔符,且 QuoteMode.ALL_NON_NULL 可控性更强
  • 禁用 BufferedWriter.write(line + "\n") 这类裸写法 —— 换行符在 Windows/Linux 下不一致,库会自动适配

容易被忽略的一点:CSV 文件的 BOM 头。中文 Excel 打开乱码,大概率是因为没加 \uFEFF。用 Commons CSV 时需手动在输出流开头写入:

try (OutputStream os = response.getOutputStream()) {
    os.write(0xEF); os.write(0xBB); os.write(0xBF); // UTF-8 BOM
    try (CSVPrinter printer = new CSVPrinter(new OutputStreamWriter(os, StandardCharsets.UTF_8), 
            CSVFormat.DEFAULT.withQuoteMode(QuoteMode.ALL_NON_NULL))) {
        printer.printRecord("ID", "姓名", "金额");
        for (Order o : orders) {
            printer.printRecord(o.getId(), o.getName(), o.getAmount());
        }
    }
}

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

160

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1030

2023.08.02

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

887

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

462

2024.06.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.6万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号