IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> Java csv导出下载 -> 正文阅读

[开发工具]Java csv导出下载

主要用于页面直接下载csv。

上代码 !

serviceImpl:

 public void deviceExportExcel(HttpServletResponse response) throws Exception {
        
        //表头
        Map<String, String> header = new LinkedHashMap<>();
        header.put("name", "名字");
        header.put("age", "年龄");
        header.put("sex", "性别");
    
        //结构数据
        List<Map<String,String>> dataList = new ArrayList<>();  //组装自己的数据。
        //例:
              Map<String,String> map = new HashMap<>();
              map.put("name","张三");
              map.put("age","20");  
              map.put("sex","男");  
              dataList.add(map);
              ap<String,String> map1 = new HashMap<>();
              map1.put("name","李四");
              map1.put("age","21");  
              map1.put("sex","男");  
              dataList.add(map1);

        CsvUtils.write(response,header,dataList);
    }

工具类:CsvUtils

import com.csvreader.CsvWriter;
import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.math.BigDecimal;
import java.nio.charset.Charset;
import java.util.*;


public class CsvUtils {

    public static void write(HttpServletResponse response,Map<String, String> header,List<Map<String,String>> dataList){
        try {
            //创建临时csv文件
            File tempFile = createTempFile(header,dataList);
            //输出csv流文件,提供给浏览器下载
            outCsvStream(response, tempFile);
            //删除临时文件
            deleteFile(tempFile);

        } catch (IOException e) {
            System.out.println("导出失败");
        }
    }

    public static File createTempFile(Map<String, String> header,List<Map<String, String>> datas) throws IOException {
        File tempFile = File.createTempFile("vehicle", ".csv");
        CsvWriter csvWriter = new CsvWriter(tempFile.getCanonicalPath(), ',', Charset.forName("UTF-8"));
        // 写表头
        List<String> nameList = new ArrayList<>();
        Set<String> strings = header.keySet();
        for (String srt : strings){
            nameList.add(header.get(srt));
        }
        String[] headers = StringUtils.join(nameList,",").split(",");
        csvWriter.writeRecord(headers);
        for (Map<String,String> data : datas) {
            //这里如果数据不是String类型,请进行转换
            for (String srt : strings){
                String s =data.get(srt);
                csvWriter.write(s);
            }
            csvWriter.endRecord();
        }
        csvWriter.close();
        return tempFile;
    }
    /**
     * 写入csv结束,写出流
     */
    public static void outCsvStream(HttpServletResponse response, File tempFile) throws IOException {
        java.io.OutputStream out = response.getOutputStream();
        byte[] b = new byte[10240];
        java.io.File fileLoad = new java.io.File(tempFile.getCanonicalPath());
        response.reset();
        response.setContentType("application/csv");
        response.setHeader("content-disposition", "attachment; filename=export.csv");
        java.io.FileInputStream in = new java.io.FileInputStream(fileLoad);
        int n;
        //为了保证excel打开csv不出现中文乱码
        out.write(new   byte []{( byte ) 0xEF ,( byte ) 0xBB ,( byte ) 0xBF });
        while ((n = in.read(b)) != -1) {
            //每次写入out1024字节
            out.write(b, 0, n);
        }
        in.close();
        out.close();
    }

    /**
     * 删除单个文件
     *
     * @return 单个文件删除成功返回true,否则返回false
     */
    public static boolean deleteFile( File file) {
        // 如果文件路径所对应的文件存在,并且是一个文件,则直接删除
        if (file.exists() && file.isFile()) {
            if (file.delete()) {
                return true;
            } else {
                return false;
            }
        } else {
            return false;
        }
    }

    public static BigDecimal getNumbersSum(String a) {
        BigDecimal c = new BigDecimal(a);
        //与参数相等返回0、小于参数返回 -1、大于参数返回 1。
        return c.compareTo(new BigDecimal("0.00000000")) == 0 ? new BigDecimal("0") : c;
    }


}

结果:

注:也是边学边写,如有错误请指出,有不懂的,可留言,互相交流学习。

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 13:19:41  更:2022-03-06 13:21:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 18:21:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码