gpt4 book ai didi

java - 如何使用 servlet 创建 CSV 文件?

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:31:37 28 4
gpt4 key购买 nike

我想从 servlet 下载 CSV 文件。我在对象数组 (object[]) 中有数据,我需要将其写入 CSV 并下载。

你能帮我如何在 servlet 类中做到这一点吗?

最佳答案

如何Object[]曾代表 CSV 数据?它包含一行多列还是多行一列?我想 Object[][]List<List<Object>>更有意义。

无论如何,在创建 CSV 文件时,您必须遵守 RFC4180 spec .基本上很简单,只有 3 个严格的规则:

  1. 字段以逗号分隔。
  2. 如果逗号出现在字段中,则该字段必须用双引号引起来。
  3. 如果一个字段中出现双引号,则该字段必须用双引号括起来,并且该字段中的双引号必须用另一个双引号转义。

这是一个基于 List<List<T>> 的启动示例。作为来源和 OutputStream作为目的地。

public static <T> void writeCsv (List<List<T>> csv, char separator, OutputStream output) throws IOException {
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(output, "UTF-8"));
for (List<T> row : csv) {
for (Iterator<T> iter = row.iterator(); iter.hasNext();) {
String field = String.valueOf(iter.next()).replace("\"", "\"\"");
if (field.indexOf(separator) > -1 || field.indexOf('"') > -1) {
field = '"' + field + '"';
}
writer.append(field);
if (iter.hasNext()) {
writer.append(separator);
}
}
writer.newLine();
}
writer.flush();
}

以下是如何在 Servlet 中使用它:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
List<List<Object>> csv = getItSomehow();
response.setHeader("Content-Type", "text/csv");
response.setHeader("Content-Disposition", "attachment;filename=\"file.csv\"");
writeCsv(csv, ';', response.getOutputStream());
}

(请注意,基于欧洲的语言环境对 CSV 文件使用分号而不是逗号,请随意更改)

Content-Dispositionattachment将强制执行另存为对话。请注意,MSIE 有不接受 filename 的错误行为。作为另存为对话框中的默认文件名,但它取而代之的是路径信息的最后一部分。因此,如果这个 servlet 例如被 http://example.com/csv 调用, 然后你会得到 csv作为默认文件名。而是将其附加到路径信息中,如下所示 http://example.com/csv/file.csv . servlet 应该只映射到 url-pattern 上的 /csv/*而不是 /csv .

关于java - 如何使用 servlet 创建 CSV 文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3190303/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com