导出到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

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

SpringBoot+EasyPOI轻松实现Excel和Word导出PDF

《SpringBoot+EasyPOI轻松实现Excel和Word导出PDF》在企业级开发中,将Excel和Word文档导出为PDF是常见需求,本文将结合​​EasyPOI和​​Aspose系列工具实... 目录一、环境准备与依赖配置1.1 方案选型1.2 依赖配置(商业库方案)二、Excel 导出 PDF