POI导出excel单元格为文本的模板

POI导出excel单元格为文本的模板

1、第一步Controller

String[] columnArr = {"姓名", "学号", "手机号"};
		//导出题目Excel创建HSSFWorkbook
		XSSFWorkbook wb = userBaseInfoService.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;片

2、第二步Service

public XSSFWorkbook createTemplateHSSFWorkbook(String[] columnArr) throws IntrospectionException,
            IllegalArgumentException, IllegalAccessException,
            InvocationTargetException {

        // 第一步,创建一个webbook,对应一个Excel文件
        XSSFWorkbook wb = new XSSFWorkbook();
        // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
        XSSFSheet sheet = wb.createSheet("模板");
        XSSFDataFormat format = wb.createDataFormat();
        // 设置列宽和设置单元格格式为纯文本
        CellStyle textStyle = wb.createCellStyle();
        textStyle.setDataFormat(format.getFormat("@"));
        for (int i = 0,length = columnArr.length; i < length; i++) {
            sheet.setColumnWidth(i, 6000);
            sheet.setDefaultColumnStyle(i,textStyle);
        }

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

        // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
        XSSFRow row = sheet.createRow((int) 0);
        row.setHeight((short) 300);
        // 第四步,创建单元格,并设置值表头 设置表头居中
        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;
    }

其中
XSSFDataFormat format = wb.createDataFormat();
textStyle.setDataFormat(format.getFormat("@"));
for (int i = 0,length = columnArr.length; i < length; i++) {
sheet.setColumnWidth(i, 6000);
sheet.setDefaultColumnStyle(i,textStyle);
}
这里是设置没列的单元格格式为文本。

猜你喜欢

转载自blog.csdn.net/liujianjun1536500976/article/details/88055476