poi导出实例excel

@GetMapping("/devices/export")
@Timed
public void exportAllDeviceOut(DeviceCriteria criteria, HttpServletResponse response) throws IOException {
log.debug("REST request to get OrgMembers by criteria: {}", criteria);

List<DeviceDTO> devices = deviceQueryService.findByCriteria(criteria);

Map<String, Object[]> rows = new TreeMap<>();
rows.put("1", new Object[]{"单位名称", "设备号", "绑定时间", "设备地址", "物联网卡号", "类型", "状态"});
for (int i = 0; i < devices.size(); i++) {
DeviceDTO device = devices.get(i);
rows.put(String.valueOf(i + 2), new Object[]{
device.getOrganizationName(),
device.getHardwareId(),
device.getBindDate(),
device.getHardwareAddress(),
device.getNetCard(),
device.getHardwareModel(),
device.isIsDisabled() ? "已禁用" : "已启用"
});
}

Workbook workbook = createWorkbookFromRows(rows);
String safeFileName = URLEncoder.encode("设备", "UTF-8");
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setHeader("Content-disposition", "attachment; filename=" + safeFileName + ".xlsx");
workbook.write(response.getOutputStream());
}

private XSSFWorkbook createWorkbookFromRows(Map<String, Object[]> rows) {
//Create blank workbook
XSSFWorkbook workbook = new XSSFWorkbook();

//Create a blank sheet
XSSFSheet spreadsheet = workbook.createSheet("设备 ");

//Create row object
XSSFRow row;

//Iterate over data and write to sheet
Set<String> keyid = rows.keySet();
int rowid = 0;

for (String key : keyid) {
row = spreadsheet.createRow(rowid++);
Object[] objectArr = rows.get(key);
int cellid = 0;

for (Object obj : objectArr) {
Cell cell = row.createCell(cellid++);
cell.setCellValue((String) obj);
}
}
return workbook;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值