java使用poi把从数据库中取出的数据写入到excel文件中并保存到指定文件路径

  有时候我们要把从数据库中取出的数据导入到excel中,使取到的数据看起来更加的直观和方便,在java中如何实现取到的数据导入到excel中呢?以下就是使用poi工具吧数据写入excel文件中的解决方法:

Excel表格扩展名有.xlsx和.xls两种格式

       百度上对两种文件的介绍有很多就不一一列举,基本的不同总结下来有以下几点:

  在java中读取和写入.xls格式使用maven导入jar包: 

<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.16</version>
</dependency>

  在java中读取和写入.xlsx格式使用maven导入jar包:

<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.16</version>
</dependency>

  然后就可以使用jar包读取excel文件,并保存到本地指定的位置,首先把从数据库中取出的信息放到一个list中,然后从list中一一读取数据,写入到excel文件中,由于后面还有需求约定好使用.xlsx文件,这里生成的excel文件类型便是.xlsx文件,如果需求对文件类型没有要求,尽量生成.xls文件。

复制代码

/**
 *
 * @param stuList 从数据库中查询需要导入excel文件的信息列表
 * @return 返回生成的excel文件的路径
 * @throws Exception
 */
public static String stuList2Excel(List<Student> stuList) throws Exception {
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
    SimpleDateFormat sdf1 = new SimpleDateFormat("yyyyMMdd hhmmss");
    Workbook wb = new XSSFWorkbook();
    //标题行抽出字段
    String[] title = {"序号","学号", "姓名", "性别", "入学时间", "住址", "手机号", "其他信息"};
    //设置sheet名称,并创建新的sheet对象
    String sheetName = "学生信息一览";
    Sheet stuSheet = wb.createSheet(sheetName);
    //获取表头行
    Row titleRow = stuSheet.createRow(0);
    //创建单元格,设置style居中,字体,单元格大小等
    CellStyle style = wb.createCellStyle();
    Cell cell = null;
    //把已经写好的标题行写入excel文件中
    for (int i = 0; i < title.length; i++) {
        cell = titleRow.createCell(i);
        cell.setCellValue(title[i]);
        cell.setCellStyle(style);
    }
    //把从数据库中取得的数据一一写入excel文件中
    Row row = null;
    for (int i = 0; i < stuList.size(); i++) {
        //创建list.size()行数据
        row = stuSheet.createRow(i + 1);
        //把值一一写进单元格里
        //设置第一列为自动递增的序号
        row.createCell(0).setCellValue(i + 1);
        row.createCell(1).setCellValue(stuList.get(i).getStuId());
        row.createCell(2).setCellValue(stuList.get(i).getStuName());
        row.createCell(3).setCellValue(stuList.get(i).getGender());
        //把时间转换为指定格式的字符串再写入excel文件中
        if (stuList.get(i).getEnterTime() != null) {
            row.createCell(4).setCellValue(sdf.format(stuList.get(i).getEnterTime()));
        }
        row.createCell(5).setCellValue(stuList.get(i).getAddress());
        row.createCell(6).setCellValue(stuList.get(i).getPhone());
        row.createCell(7).setCellValue(stuList.get(i).getOtherInfo());

    }
    //设置单元格宽度自适应,在此基础上把宽度调至1.5倍
    for (int i = 0; i < title.length; i++) {
        stuSheet.autoSizeColumn(i, true);
        stuSheet.setColumnWidth(i, stuSheet.getColumnWidth(i) * 15 / 10);
    }
    //获取配置文件中保存对应excel文件的路径,本地也可以直接写成F:excel/stuInfoExcel路径
    String folderPath = ResourceBundle.getBundle("systemconfig").getString("downloadFolder") + File.separator + "stuInfoExcel";

    //创建上传文件目录
    File folder = new File(folderPath);
    //如果文件夹不存在创建对应的文件夹
    if (!folder.exists()) {
        folder.mkdirs();
    }
    //设置文件名
    String fileName = sdf1.format(new Date()) + sheetName + ".xlsx";
    String savePath = folderPath + File.separator + fileName;
    // System.out.println(savePath);

    OutputStream fileOut = new FileOutputStream(savePath);
    wb.write(fileOut);
    fileOut.close();
    //返回文件保存全路径
    return savePath;
}

复制代码

   注意事项:

  1. 这里的数据使用的是数据库中的测试数据,生产环境数据字段会更多,数据会更复杂,要根据不同的数据进行处理。
  2. poi工具对生成的单元格宽度即使设置了自适应,有时宽度也无法显示全部数据,所以在此基础上,根据情况把单元格宽度再增加一些,这里是把单元格宽度再增加1.5倍。
  3. 文件保存在同一个文件夹中会导致重名,所以文件名中最好包含时间,这样的话在单人使用的时候回避免出现文件名重复的情况。

  根据返回的路径名手动找到的文件:

  得到的excel数据如下

   以上就是从数据库中读取数据写入excel文件并保存到指定位置,后续还有前端请求下载excel文件,后端的处理方法;前端上传excel文件,读取其中的文件信息,并把对应的数据取出存入到数据库中......

  未完待续。。。。。。

郑州市不孕不育医院

郑州不孕不育

郑州男科医院

猜你喜欢

转载自blog.csdn.net/qq_42564846/article/details/83897379