easyExcel导出扩展名为.xlsx的文件并设置文件名
时间: 2023-05-14 16:05:21 浏览: 1076
你可以使用以下代码来实现:
```
// 创建工作簿
Workbook workbook = new XSSFWorkbook();
// 创建工作表
Sheet sheet = workbook.createSheet("Sheet1");
// 创建行
Row row = sheet.createRow(0);
// 创建单元格
Cell cell = row.createCell(0);
cell.setCellValue("Hello World!");
// 导出文件
try {
FileOutputStream outputStream = new FileOutputStream("文件名.xlsx");
workbook.write(outputStream);
outputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
```
其中,你需要将"文件名"替换为你想要设置的文件名。
相关问题
//File file=new File(this.getClass().getResource("/").getPath()+"template"+File.separator+"receipt.xlsx"); // File file=new File(this.getClass().getResourceAsStream("/template/receipt.xlsx"); InputStream inputStream = this.getClass().getResourceAsStream("/template/receipt.xlsx"); File file = new File("路径/文件名.xlsx"); // 请替换为你想要保存的路径和文件名 response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); String fileName = URLEncoder.encode("电力收费系统报表 - 电费收据.xlsx", "utf-8"); response.setHeader("Content-disposition", "attachment; filename=" + new String(fileName.getBytes("UTF-8"), "ISO-8859-1")); out = response.getOutputStream(); bos = new BufferedOutputStream(out); //读取Excel ExcelWriter excelWriter = EasyExcel.write(bos).withTemplate(file.getPath()).build(); WriteSheet writeSheet = EasyExcel.writerSheet().build(); // 写入Excel数据 //excelWriter.fill(exporChargeUsers, writeSheet); excelWriter.fill(map, writeSheet); excelWriter.finish(); bos.flush();服务器导出没数据
根据你提供的代码,问题可能出在以下几个地方:
1. 数据填充问题:你使用了 EasyExcel 库来进行数据填充。请确保 `map` 对象中存储了正确的数据,并且模板文件中的字段与 `map` 中的键名相匹配。如果你使用了 `excelWriter.fill(exporChargeUsers, writeSheet)` 方法,那么请确保 `exporChargeUsers` 对象中存储了正确的数据。
2. 路径问题:请确保你将 `"路径/文件名.xlsx"` 替换为实际的导出路径和文件名,确保路径正确,并且你有写入该路径的权限。
3. 模板文件问题:请确保模板文件 `receipt.xlsx` 存在于 `/template/` 目录下,并且该目录位于你的类路径下。
4. 输出流问题:请确保 `bos` 对象和 `out` 对象正确地与服务器的输出流建立关联,并且在写入数据后调用了 `bos.flush()` 方法来刷新输出流。
如果你仍然遇到问题,建议逐步调试代码,打印相关变量和日志信息,以便更好地定位问题所在。
easyExcel导出设置文件名
你可以使用以下代码设置EasyExcel导出的文件名:
```java
response.setHeader("Content-disposition", "attachment; filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xlsx");
```
其中,`fileName`是你想要设置的文件名。这段代码会将文件名设置为`fileName.xlsx`,并将其作为附件下载。如果你想要导出其他格式的文件,可以将`.xlsx`替换为其他文件格式的后缀名即可。
阅读全文