Java POI(一)

POI(一)

Java POI-3.17

单元格相关
  • 文本格式

Excel-设置单元格格式

通常,Excel的单元格格式能够根据输入的值进行智能转换(其实没那么智能),所以更多的 是在智能转换不满足需求时,需要手动规范单元格格式,即自定义格式。

CellStyle通过void setDataFormat(short fmt);方法设置单元格自定义格式。但由于参数是short类型,所以需要通过DataFormat提供的**short getFormat(String format);**方法进行转换,该方法format参数的值只要传入如上图中Excel支持的类型即可。

示例:

    /**
     * 设置单元格自定义格式
     * @param workbook 工作薄
     * @param format 自定义格式
     * @return
     */
    public static CellStyle getCellStyleDataFormat(Workbook workbook, String format) {
    	CellStyle cellStyle = workbook.createCellStyle();
        DataFormat dataFormat = workbook.createDataFormat();
        cellStyle.setDataFormat(dataFormat.getFormat(format));
        return cellStyle;
    }

!单元格文本格式是弱约束(不知道是不是这么定义),如果输入的值符合或者能够被转换为设置的格式(数字、日期、货币等),那么Excel将按设置的单元格格式进行展示。否则,如果数据不能匹配设置的格式,那么格式将以"文本"格式进行展示,即单元格不做任何处理直接展示传入的值。如果要做正确性验证,通过单元格数据有效性DVConstraint绑定实现(先挖个坑)。

  • 边框

CellStyle支持设置单元格的上下左右边框样式。BorderStyle枚举中定义了边框的类型。

如下:

    /** 
	 * 边框设置
     * @param workbook
     * @return
     */
    public static CellStyle getCellStyleBorder(Workbook workbook) {
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setBorderTop(BorderStyle.THIN);
        cellStyle.setBorderBottom(BorderStyle.THIN);
        cellStyle.setBorderLeft(BorderStyle.THIN);
        cellStyle.setBorderRight(BorderStyle.THIN);
        return cellStyle;
    }
  • 字体

Font接口提供了一系列的方法设置字体、大小、颜色、粗体等字体样式。而CellStyle接口则提供了**void setFont(Font font);**方法用于设置单元格字体。

如下:

    /**
     * 设置单元格字体
     * @param workbook 工作薄
     * @return
     */
public static CellStyle getCellStyleFont(Workbook workbook) {
        CellStyle cellStyle = workbook.createCellStyle();
        Font font = workbook.createFont();
    	/*
    	//设置字体样式
        font.setFontName("Times New Roman"); //设置字体类型
        font.setFontHeightInPoints((short) 10); //设置字体大小
        font.setBold(true);//字体加粗
        font.setColor(Font.COLOR_RED);//红色
    	*/
    	//设置单元格字体样式
        cellStyle.setFont(font);
        return cellStyle;
    }
  • 填充

填充同样可以通过CellStyle直接设置。通过**void setFillPattern(FillPatternType fp);设置填充的样式,通过void setFillForegroundColor(short bg);**设置填充的颜色。

如下:

    /** 
	 * 填充设置
     * @param workbook
     * @return
     */
    public static CellStyle getCellStyleBorder(Workbook workbook) {
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        cellStyle.setFillForegroundColor(IndexedColors.ORANGE.getIndex());
        return cellStyle;
    }
  • CellStyle样式覆盖

CellStyle使用不当可能会出现样式覆盖的问题。

如下:

public void demo1(CellStyle cellStyle, Row row) {
    	/*
    	1、假设这里对cellStyle设置了单元格样式
    	*/
    	Cell cell1 = row.createCell(0);//在row行1列创建一个单元格
    	cell1.setCellStyle(cellStyle);//设置单元格样式
    	/*
    	2、假设这里对cellStyle单元格样式进行了修改
    	*/
    	Cell cell2 = row.createCell(1);//在row行2列创建一个单元格
    	cell2.setCellStyle(cellStyle);//设置单元格样式
    }

CellStyle对象实例后,作用域在整个Workbook对象,而不是Cell独有。所以,如果多个Cell对象需要不同的样式风格,那么CellStyle对象同样需要设置多个(Poi中规定了最大数量为4000)。否则,被修改的CellStyle对象同样会作用到Workbook中所有setCellStyle该cellStyle的Cell对象中,导致之前设置的单元格风格被覆盖。

  • 单元格样式克隆

CellStyle提供了**void cloneStyleFrom(CellStyle source);**方法用于克隆样式。通过样式继承的思路,不仅可以提高CellStyle对象的利用率,还可以减少很多的代码量。

如下:

    /**
     * 克隆原CellStyle,防止之前设置的样式被覆盖
     * @param workbook
     * @param source
     * @return
     */
    public static CellStyle cloneCellStyleFrom(Workbook workbook, CellStyle source) {
        CellStyle dest = workbook.createCellStyle();
        dest.cloneStyleFrom(source);
        /*
        这里可以在克隆样式的基础上做一些样式修改
        */
        return dest;
    }
  • 按列设置单元格样式

通常单元格样式是按列进行样式设置的,所以Sheet提供了一个**void setDefaultColumnStyle(int column, CellStyle style);**方法进行按列为单位设置单元格样式。

如下:

    public void demo2(Sheet sheet, int colIndex, CellStyle cellStyle) {
        sheet.setDefaultColumnStyle(colIndex, cellStyle);
    }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java POI是一个用于操作Microsoft Office文档的开源Java API框架。它支持读取、写入和编辑各种Office格式的文档,如Word文档、Excel电子表格和PowerPoint演示文稿。 使用Java POI可以方便地生成、修改和处理Office文档。它提供了一组丰富的API,可以创建各种样式的文档,包括设置字体、颜色、表格、图表等。同时,它也支持将数据从数据库中读取,然后将其填充到模板文件中,从而生成自定义的报表、邮件等。 Java POI的主要功能包括: 1. 读取和写入Excel文件:可以将Excel文件读取为Java对象,也可以将Java对象写入到Excel文件中。通过POI,我们可以操作Excel中的单元格、行、列以及样式等信息。 2. 处理Word文档:可以读取、创建和编辑Word文档,可以设置字体、段落样式、页眉页脚、表格等。 3. 操作PowerPoint演示文稿:可以创建和编辑PowerPoint演示文稿,可以设置幻灯片的布局、文本框、图表、图片等。 Java POI具有良好的兼容性和稳定性,可以与各种版本的Microsoft Office套件无缝集成。同时,它还支持多种文件格式,包括xls、xlsx、doc、docx、ppt、pptx等。 总之,Java POI是一个功能强大的工具,可以帮助开发者在Java中处理各种Office文档。无论是生成报表、处理数据还是编辑文档,都可以通过Java POI实现。它为我们提供了丰富的API,使得操作Office文件变得更加简单和高效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值