小功能实现(十三)使用POI的方式导出Excel表

前言

  • 通过POI的方式将获得的数据转换成Excel表格的形式

步骤

  • 直接上代码,Controller层
  • 笨蛋的我本来还以为HttpServletResponse还要返回,后来发现根本不用,它会自行返回
	//导出电缆信息表
    @RequestMapping(value = "/exportCableLineInfoByExcel.do")
    public void exportCableLineInfoByExcel(EvCableLineInforVo evCableLineInforVo, HttpServletResponse httpServletResponse){
        evCablelineinforService.exportCableLineInfoByExcel(evCableLineInforVo,httpServletResponse);
    }
  • 服务实现层
@Override
public void exportCableLineInfoByExcel(EvCableLineInforVo evCableLineInforVo,HttpServletResponse httpServletResponse) {
    OutputStream outputStream = null;
    try {
		//这是准备转换的数据
        List<EvCablelineinfor> evCablelineinforList = new ArrayList<>();
;
        //创建xls文件
        HSSFWorkbook hssfWorkbook = new HSSFWorkbook();

        //创建水平居中的样式
        HSSFCellStyle cellStyle = hssfWorkbook.createCellStyle();
        cellStyle.setAlignment(HorizontalAlignment.CENTER);

        //通过hss创建sheet
        HSSFSheet sheet = hssfWorkbook.createSheet("某某表");

        int[] width = {6000, 18000, 7000, 7000, 3000, 4000, 3000, 3000};

        //第一行的内容
        String[] str = {"名称1", "名称2", "设备1"};
        //创建第一行的表单内容
        HSSFRow row1 = sheet.createRow(0);
        //创建第一行单元格内容
        for (int i = 0; i < str.length; i++) {
            //设置宽度
            sheet.setColumnWidth(i, width[i]);
            //设置每一列的样式(居中对齐,可选)
//                sheet.setDefaultColumnStyle(i,cellStyle);
            //第一行的内容
            row1.createCell(i).setCellValue(str[i]);
            //设置第一行的居中对齐
            row1.getCell(i).setCellStyle(cellStyle);
        }

        //遍历循环数据进行添加
        for (int i = 0; i < evCablelineinforList.size(); i++) {
            EvCablelineinfor evCablelineinfor = evCablelineinforList.get(i);
            //创建第几行
            HSSFRow row2 = sheet.createRow(i + 1);
            //设置每个单元格内容
            row2.createCell(0).setCellValue(evCablelineinfor.getLoopname());
            row2.createCell(1).setCellValue(evCablelineinfor.getCablelinename());
            row2.createCell(2).setCellValue(evCablelineinfor.getStartdevice());

        }

        //获取表并写入
        outputStream = httpServletResponse.getOutputStream();
        httpServletResponse.setContentType("application/x-download");
        httpServletResponse.setCharacterEncoding("UTF-8");
        httpServletResponse.setHeader("Content-disposition", "attachment;filename=" + new String("某某表".getBytes(), "ISO8859-1") + ".xls");
        hssfWorkbook.write(outputStream);
        outputStream.close();

    } catch (Exception e) {
        e.printStackTrace();
    }
}

参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值