使用Easy Excel导出List<Map<String,Object>>类型数据

使用Easy Excel导出List<Map<String,Object>>类型数据

  • 对于利用Easy Excel导出此类型的数据时,需要将表头和表数据分别导出
  • 之后用双层for循环将表头和数据一一对应。
    @Override
    public void export(HttpServletResponse response) {
        //此时的list为list<Map<String,Object>>类型
        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
        //向集合添加数据
        Map<String, Object> map = new HashMap<>();
        map.put("name","张三");
        map.put("age","16");
        map.put("address","河南省");
        list.add(map);

        Map<String, Object> map1 = new HashMap<>();
        map1.put("name","李四");
        map1.put("age","19");
        map1.put("address","四川省");
        list.add(map1);

        Map<String, Object> map2 = new HashMap<>();
        map2.put("name","王五");
        map2.put("age","25");
        map2.put("address","北京市");
        list.add(map2);

        List<XxglFieldDefine> fList  = new ArrayList<XxglFieldDefine>();
        XxglFieldDefine x = new XxglFieldDefine();
        x.setFieldName("姓名");
        x.setFieldKey("name");
        fList.add(x);

        XxglFieldDefine x1 = new XxglFieldDefine();
        x1.setFieldName("年龄");
        x1.setFieldKey("age");
        fList.add(x1);

        XxglFieldDefine x2 = new XxglFieldDefine();
        x2.setFieldName("地址");
        x2.setFieldKey("address");
        fList.add(x2);
		
        //首先遍历出字段的key
        String[] arry = new String[fList.size()];
        for(int i=0; i<fList.size();i++){
            arry[i] = fList.get(i).getFieldKey();
        }
		//遍历出需要导出数据的表头
        String[] headArry = new String[fList.size()];
        for(int i=0; i<fList.size();i++){
            headArry[i] = fList.get(i).getFieldName();
        }
        
        List<List<Object>> dataList = new ArrayList<List<Object>>();
        //设置导出的数据内容
        for (Map<String, Object> m : list) {
            List<Object> data = new ArrayList<Object>();
            for (int i = 0; i < arry.length; i++) {
                data.add(m.get(arry[i]));
            }
            dataList.add(data);
        }
        try {
            ExcelUtil.exportNoModel(response,headArry,"测试导出",dataList);
        } catch (Exception e) {
            System.out.println("失败了导出");
        }
    }
  • 在导出的工具类中进行配置
//导出类型
public static void exportNoModel(HttpServletResponse response, String [] headMap, String fileName, List<List<Object>> dataList ){
        try {
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setCharacterEncoding("utf-8");
            String name = URLEncoder.encode(fileName, "UTF-8");
            response.setHeader("Content-disposition", "attachment;filename=" + name + ".xlsx");
        EasyExcel.write(response.getOutputStream()).head(createdHead(headMap)).sheet(fileName).doWrite(dataList);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
//处理字段的表头值
    private static List<List<String>> createdHead(String[] headMap) {
        List<List<String>> headList = new ArrayList<List<String>>();
        for (String head : headMap) {
            List<String> list = new ArrayList<String>();
            list.add(head);
            headList.add(list);
        }
        return headList;
    }
  • 14
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
使用easy excel导出Excel文件可以通过以下步骤完成: 1. 首先,确保已经安装了Java开发环境以及easyexcel的相关依赖包,例如alibaba easyexcel。 2. 导入easyexcel相关的类和包,例如`com.alibaba.excel.EasyExcel`。 3. 创建一个ExcelWriter对象,用于写入Excel文件。可以指定要生成的Excel文件的路径和文件名。 4. 创建一个Sheet对象,并设置sheet的名称。 5. 创建一个List集合,用于存储要导出数据。 6. 将数据逐一添加到List集合中。 7. 调用ExcelWriter对象的write方法,将数据写入到Sheet中。 8. 最后,调用ExcelWriter对象的finish方法,关闭资源,生成Excel文件。 下面是一个示例代码: ```java import com.alibaba.excel.EasyExcel; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.Sheet; import com.alibaba.excel.metadata.Table; import java.util.ArrayList; import java.util.List; public class ExportExcel { public static void main(String[] args) { // 创建ExcelWriter对象,并指定要生成的Excel文件的路径及名称 ExcelWriter excelWriter = EasyExcel.write("D:\\test.xlsx").build(); // 创建Sheet对象,并设置sheet的名称 Sheet sheet = new Sheet(1, 0); sheet.setSheetName("Sheet1"); // 创建一个 List 集合,用于存储要导出数据 List<List<String>> data = new ArrayList<>(); // 向 List 中逐一添加数据 List<String> item = new ArrayList<>(); item.add("姓名"); item.add("年龄"); data.add(item); item = new ArrayList<>(); item.add("张三"); item.add("25"); data.add(item); // 将数据写入到 Sheet 中 excelWriter.write(data, sheet); // 关闭资源,生成Excel文件 excelWriter.finish(); } } ``` 以上代码会生成一个名为test.xlsx的Excel文件,其中包含一个名为Sheet1的工作表,表格中有两列数据:姓名和年龄,其中姓名为张三,年龄为25。 这样就可以使用easyexcel导出Excel文件了。注意,使用easyexcel还可以导出更复杂的Excel文件,例如多个工作表、自定义样式等。详细的用法可以参考easyexcel的官方文档。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Youngk-01

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

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

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

打赏作者

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

抵扣说明:

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

余额充值