首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Java导出EXCEL 文本 表格

Java导出EXCEL 文本 表格

作者头像
六月的雨在Tencent
发布2024-03-28 19:36:59
发布2024-03-28 19:36:59
6740
举报
文章被收录于专栏:CSDNCSDN
Java导出EXCEL 文本 表格

  • 导出表格controller
    • 导出表格实现类

导出表格controller

代码语言:javascript
复制
	@RequestMapping(value = "/downloadTemplate")
	public String downloadTemplate(HttpServletRequest request, HttpServletResponse response) throws IllegalArgumentException, IllegalAccessException, InvocationTargetException, IntrospectionException, IOException {
		//查询需要导出的数据
		String[] columnArr = {"*姓名", "*学号", "手机号", "身份证号", "性别"};
		//导出题目Excel创建HSSFWorkbook
		XSSFWorkbook wb = userBaseInfoFromExcelService.createTemplateHSSFWorkbook(columnArr);
		// 将文件保存到指定位置
		response.setContentType("APPLICATION/OCTET-STREAM");
		SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
		String titleStr = "模板" + dateFormat.format(new Date());
		String title = new String(titleStr.getBytes("gb2312"),"iso-8859-1");
		response.setHeader( "Content-Disposition" ,"attachment;filename=\"" + title + ".xlsx" + "\"" );
		OutputStream ouputStream = response.getOutputStream();
		wb.write(ouputStream);
		ouputStream.flush();
		ouputStream.close();
		return null;
	}

导出表格实现类

代码语言:javascript
复制
    @Override
    public XSSFWorkbook createTemplateHSSFWorkbook(String[] columnArr) throws IntrospectionException,
            IllegalArgumentException, IllegalAccessException,
            InvocationTargetException {
        // 第一步,创建一个webbook,对应一个Excel文件
        XSSFWorkbook wb = new XSSFWorkbook();
        // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
        XSSFSheet sheet = wb.createSheet("模板");
        //设置cell格式为文本格式
        XSSFCellStyle cellStyle = wb.createCellStyle();
        XSSFDataFormat dataFormat = wb.createDataFormat();
        cellStyle.setDataFormat(dataFormat.getFormat("@"));
        // 设置列宽
        for (int i = 0,length = columnArr.length; i < length; i++) {
            sheet.setColumnWidth(i, 6000);
            //设置当前sheet格式为文本格式
            sheet.setDefaultColumnStyle(i,cellStyle);

        }

        // 设置字体大小
        XSSFFont font = wb.createFont();
        font.setFontHeightInPoints((short) 14);
        font.setBold(true);
        //font.setFontHeightInPoints((short) 12);

        // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
        XSSFRow row = sheet.createRow((int) 0);
        row.setHeight((short) 400);
        // 第四步,创建单元格,并设置值表头 设置表头居中
        XSSFCellStyle style = wb.createCellStyle();
        // 设置字体样式
        style.setFont(font);
        // 设置表头居中
        style.setAlignment(XSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式

        XSSFCell cell;
        for (int i = 0,length = columnArr.length; i < length; i++) {
            cell = row.createCell((short) i);
            cell.setCellValue(columnArr[i]);
            cell.setCellStyle(style);
        }
        return wb;
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-03-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Java导出EXCEL 文本 表格
  • 导出表格controller
    • 导出表格实现类
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档