poi导出到本地 选择本地路径 保存到本地

//poi导出excel 保存到本地

public void exportExcel(HttpServletRequest req, HttpServletResponse resp) throws IOException{

HSSFWorkbook wb = new HSSFWorkbook();
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.setContentType("application/x-download");

String filedisplay = "未匹配的产品清单.xls";
filedisplay = URLEncoder.encode(filedisplay, "UTF-8");
resp.addHeader("Content-Disposition", "attachment;filename="+ filedisplay);
HSSFSheet sheet = wb.createSheet("未匹配产品");
sheet.setColumnWidth(0, 50*160);
HSSFFont font = wb.createFont();
font.setFontName("宋体");
font.setFontHeightInPoints((short) 16);

HSSFRow row = sheet.createRow((int) 0);

HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);

HSSFCell cell = row.createCell(0);
cell.setCellValue("产品名称");

Map<String, Object> params = new HashMap<String, Object>();
params.put("userId", this.getMember().getId());
params.put("matchabled", 0);
List<Match> matchs = this.getBeanManager().listBean(Match.class, params);

for (int i = 0; i < matchs.size(); i++) {
row = sheet.createRow((int) i + 1);
Match match = (Match) matchs.get(i);
row.createCell(0).setCellValue(match.getName());
}
try {
OutputStream out = resp.getOutputStream();
wb.write(out);
out.close();
}
catch (Exception e) {
e.printStackTrace();
}
}
### Java中将List数据导出本地文件 在Java中,可以利用Apache POI库来实现将`List<String>`中的数据写入到Excel文件并保存本地。下面展示一段完整的代码示例用于说明这一过程[^1]。 ```java import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.*; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; public class ExportToListFile { public static void main(String[] args) { try { // 创建工作簿对象 Workbook workbook = new HSSFWorkbook(); // 新建一个表格sheet Sheet sheet = workbook.createSheet("Data"); // 准备要写出的数据 List<String> list = prepareData(); // 设置表头 Row headerRow = sheet.createRow(0); String[] headers = {"列1", "列2", "列3"}; for (int i = 0; i < headers.length; i++) { Cell cell = headerRow.createCell(i); cell.setCellValue(headers[i]); } // 填充数据行 fillRows(sheet, list); // 将文档保存为.xls格式的文件 saveWorkbook(workbook, "./output.xls"); } catch (IOException e) { System.out.println(e.getMessage()); } } private static List<String> prepareData() { List<String> data = new ArrayList<>(); data.add("值1,值2,值3"); return data; } private static void fillRows(Sheet sheet, List<String> dataList) { int rowNum = 1; for (String line : dataList) { Row row = sheet.createRow(rowNum++); String[] columns = line.split(","); for (int colIndex = 0; colIndex < columns.length; colIndex++) { Cell cell = row.createCell(colIndex); cell.setCellValue(columns[colIndex]); } } } private static void saveWorkbook(Workbook wb, String filePath) throws IOException { FileOutputStream fileOut = null; try { fileOut = new FileOutputStream(filePath); wb.write(fileOut); } finally { if (fileOut != null) { fileOut.close(); } wb.close(); } } } ``` 这段程序首先创建了一个HSSF的工作簿实例,并定义了一张名为“Data”的新表单。接着通过`prepareData()`方法准备了一些模拟数据存放在列表里;之后设置好表头信息并通过遍历的方式把每一项记录按照逗号分隔符拆分成多个单元格的内容填充进去。最后一步则是指定路径名以及扩展名(.xls),调用`saveWorkbook()`函数完成实际存储操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值