list对象如何转excel

list转excel

第一步:导包

 <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi</artifactId>
          <version>4.1.1</version>
         <scope>compile</scope>
  </dependency>

第二步:cv

  public static void listToExcelNull(List<?> list,OutputStream outputStream,Class<?> clazz){
      List<Map<String,String>> listMap = listToMap(list);

      listToExcel(listMap,clazz,outputStream);
  }

  private static List<Map<String, String>> listToMap(List<?> list) {
      if (Objects.isNull(list) || list.size() == 0 ){
          return null;
      }
      List<Field> listFiled = Arrays.asList(list.get(0).getClass().getDeclaredFields());

      return list
              .stream()
              .map(s-> listFiled.stream().collect(Collectors.toMap(Field::getName, value ->getValue(value,s))))
              .collect(Collectors.toList());
  }

  private static String getValue(Field value, Object clazz) {
      String v;
      try {
          value.setAccessible(true);
          v = (String) value.get(clazz);
      }catch (IllegalAccessException e){
          e.printStackTrace();
          v = "";
      }
      return v;
  }


  public static void listToExcel(List<Map<String,String>> list,Class<?> clazz,OutputStream outputStream){
      listToExcel(list,getHeader(clazz),outputStream);
  }

  private static List<String> getHeader(Class<?> clazz) {
      return Arrays
              .stream(clazz.getDeclaredFields())
              .map(Field::getName)
              .collect(Collectors.toList());
  }
  public static void listToExcel(List<Map<String,String>> list,List<String> header,OutputStream outputStream){
      HSSFWorkbook workbook =  new HSSFWorkbook();
      HSSFSheet sheet = workbook.createSheet();
      //创建第一行
      HSSFRow row = sheet.createRow(0);
      HSSFCell cell;
      for (int i = 0 ; i < header.size() ;i ++){
          cell = row.createCell(i);
          cell.setCellValue(header.get(i));
      }
      //创建内容
      for (int i = 0 ; i < list.size() ;i ++){
          HSSFRow nextRow = sheet.createRow(i+1);
          Map<String,String> map = list.get(i);
          HSSFCell dataCell;
          for (int j = 0 ; j < header.size() ;j ++){
              dataCell = nextRow.createCell(j);
              String value = map.get(header.get(j));
              dataCell.setCellValue(value);
          }
      }
      try {
          workbook.write(outputStream);
      }catch (IOException ioException){
          ioException.printStackTrace();
      }
  }

第三步:调接口

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用 Apache POI 库来将 Java List 对象换为 Excel 文件。以下是一个示例代码: ```java import java.io.FileOutputStream; import java.io.IOException; import java.util.List; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ListToExcelConverter { public void convert(List<Object[]> data, String filePath) throws IOException { XSSFWorkbook workbook = new XSSFWorkbook(); org.apache.poi.ss.usermodel.Sheet sheet = workbook.createSheet("Sheet1"); int rowNum = 0; for (Object[] rowData : data) { Row row = sheet.createRow(rowNum++); int colNum = 0; for (Object field : rowData) { Cell cell = row.createCell(colNum++); if (field instanceof String) { cell.setCellValue((String) field); } else if (field instanceof Integer) { cell.setCellValue((Integer) field); } else if (field instanceof Double) { cell.setCellValue((Double) field); } else if (field instanceof Boolean) { cell.setCellValue((Boolean) field); } } } try (FileOutputStream outputStream = new FileOutputStream(filePath)) { workbook.write(outputStream); } } } ``` 在上面的代码中,我们使用 `XSSFWorkbook` 类来创建一个新的 Excel 工作簿,然后创建一个名称为 "Sheet1" 的工作表。接着,我们遍历 Java List 对象中的数据,将它们添加到 Excel 表格中。最后,我们将 Excel 文件保存到指定的文件路径中。 你可以使用以下代码将 Java List 对象换为 Excel 文件: ```java List<Object[]> data = ... // 获取你要换的数据 String filePath = "data.xlsx"; // 指定保存的文件路径 ListToExcelConverter converter = new ListToExcelConverter(); converter.convert(data, filePath); ``` 注意,上面的代码仅适用于 Excel 2007 或更高版本的 ".xlsx" 文件。如果你需要处理早期版本的 Excel 文件(例如 ".xls" 文件),则需要使用 HSSF API,而不是 XSSF API。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值