Java生成csv 

Java生成csv 

List<Map<String, Object>> list, LinkedHashMap<String, Object> titleMap

titleMap的k值和value值一样

titleMap的k值对应List<Map<String, Object>中的k值表示与标题栏对应


import cn.hutool.core.text.csv.CsvUtil;
import cn.hutool.core.text.csv.CsvWriter;
import cn.hutool.core.util.CharsetUtil;
import com.dtroad.ieasweb.util.StrUtil;

import java.io.File;
import java.util.*;

/**
 * author ss
 * createTime 2020/4/23
 * package 
 * desc 生成csv文件
 ***/
public class CsvBigExportUtil {


    public static Map<String, Object> export(List<Map<String, Object>> list, LinkedHashMap<String, Object> titleMap, String Path, String fileName) {
        String filePath = Path + "/" + fileName;
        CsvWriter writer = CsvUtil.getWriter(filePath, CharsetUtil.CHARSET_UTF_8);
        //构建csv头部
        String[] head = new String[titleMap.size()];
        Iterator<Map.Entry<String, Object>> headEntries = titleMap.entrySet().iterator();
        int h = 0;
        while (headEntries.hasNext()) {
            Map.Entry<String, Object> entry = headEntries.next();
            Object value = entry.getValue();
            head[h] = value.toString();
            h++;
        }
        //先写入头部栏目再写入栏目内容,大批量随便导出
        //获取列表中数据必须是按照列表的数据必须对应头部栏目
        writer.write(head);
        //根据titleMap的key值去获取
        for (int i = 0; i < list.size(); i++) {
            Map map = list.get(i);
            String[] content = new String[map.size()];
            int j = 0;
            Iterator<Map.Entry<String, Object>> tempHead = titleMap.entrySet().iterator();
            while (tempHead.hasNext()) {
                Map.Entry<String, Object> entry = tempHead.next();
                String key = entry.getKey();
                content[j] = "" + StrUtil.toString(map.get(key)) + "";
                j++;
            }
            writer.write(content);
        }
        writer.close();
        Map<String, Object> resultMap = new HashMap<>();
        resultMap.put("file", new File(filePth));
        resultMap.put("path", filePth);
        return resultMap;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我来秋风扫落叶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值