导出到csv 文件(逗号分隔文件)不用poi 导出文件

2024-05-16 12:18
文章标签 导出 csv 不用 poi 逗号 分隔

本文主要是介绍导出到csv 文件(逗号分隔文件)不用poi 导出文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

csv 文件的注意事项: 以逗号分隔; 如果内容中已经存在了逗号,如果内容中已经存在了逗号;  对 其内容进行" 张,三"  这样进行两端加双引号转意思;

如果 数据原来就存在"   那么在 " 前面加上一个"  转义也就是"" 这样; 如 你"好   会转义为  你"" 好;  


        // 设置响应流编码 gbk  因为 excel 打开文件默认的编码 是gbk ; 所以需要在下面设置输出流的编码;
   //     response.setCharacterEncoding("gbk");


import sun.misc.BASE64Encoder;
import cn.itcast.estore.domain.Orderitem;

/**
 * 导出榜单
 *
 * @author seawind
 *
 */
public class ExportRankServlet extends HttpServlet {

    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        // 需要榜单数据 ---- 从ServletContext 中获得榜单数据
        List<Orderitem> rank = (List<Orderitem>) getServletContext()
                .getAttribute("rank");
        // 文件下载功能  1 先设置两个头信息;
        // 设置文件类型 Content-Type (day20里面有)  getServletContext().getMimeType("rank.csv")获取改文件名的contenttype;
        response.setContentType(getServletContext().getMimeType("rank.csv"));
        // 以附件形式下载 Content-Disposition --- 附件名中文
        Date date = new Date(System.currentTimeMillis());// 构造java.sql.Date 当前时间
        String fileName = "estore商城销售排行榜_" + date + ".csv";

        // 设置附件中文名
        String agent = request.getHeader("user-agent");
        if (agent.contains("MSIE")) {
            // IE --- URL编码
            fileName = URLEncoder.encode(fileName, "utf-8");
        } else if (agent.contains("Mozilla")) {
            // 火狐
            BASE64Encoder base64Encoder = new BASE64Encoder();
            fileName = "=?UTF-8?B?"
                    + new String(base64Encoder.encode(fileName
                            .getBytes("UTF-8"))) + "?=";
        }

        response.setHeader("Content-Disposition", "attachment;filename="
                + fileName);

//--------------以上为设置头信息 ; -----------------





        // 设置响应流编码 gbk  因为 excel 打开文件默认的编码 是gbk ; 所以需要在这里设置输出流的编码;
        response.setCharacterEncoding("gbk");

        // 文件下载
        PrintWriter out = response.getWriter();
        // 先写表头
        out.println("排名,商品编号,名称,单价,销售数量");
        // 遍历榜单数据   
        for (int i = 0; i < rank.size(); i++) {
            Orderitem orderitem = rank.get(i);

            // 输出csv数据时,对商品名称 ,进行特殊处理 --- 转义 ,和"          因为这里只是productname可能含有, 或者
            out.println((i + 1) + "," + orderitem.getProduct().getId() + ","
                    + convert(orderitem.getProduct().getName()) + ","
                    + orderitem.getProduct().getPrice() + ","
                    + orderitem.getBuynum());
        }

        out.flush();
    }

    // 转义 商品名称中 , 和 "
    private String convert(String name) {
        // 如果name 中存在 " 转成 ""
        name = name.replace("\"", "\"\"");                    // 一个 "  转换为 ""     \ 为转义符号
        // 如果包含,返回 name 两端 添加 ""
        return "\"" + name + "\"";
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request, response);
    }

}

这篇关于导出到csv 文件(逗号分隔文件)不用poi 导出文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994888

相关文章

java中使用POI生成Excel并导出过程

《java中使用POI生成Excel并导出过程》:本文主要介绍java中使用POI生成Excel并导出过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求说明及实现方式需求完成通用代码版本1版本2结果展示type参数为atype参数为b总结注:本文章中代码均为

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

Java利用poi实现word表格转excel

《Java利用poi实现word表格转excel》这篇文章主要为大家详细介绍了Java如何利用poi实现word表格转excel,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、每行对象类需要针对不同的表格进行对应的创建。package org.example.wordToEx

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

C# winform操作CSV格式文件

《C#winform操作CSV格式文件》这篇文章主要为大家详细介绍了C#在winform中的表格操作CSV格式文件的相关实例,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录实例一实例效果实现代码效果展示实例二实例效果完整代码实例一实例效果当在winform界面中点击读取按钮时 将csv中

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch