Apache POI 设置宽度和行高

 

       FileOutputStream fos = new FileOutputStream("D:\\15.xls");
 
        HSSFWorkbook wb = new HSSFWorkbook();
 
        /**
         * ========================================================
         *                             设置cell宽度
         *  通过sheet 对象,setColumnWidth设置cell的宽度
         * ========================================================
         */
        HSSFSheet sheet = wb.createSheet("sheet1");
        // api 段信息 Set the width (in units of 1/256th of a character width)
        sheet.setColumnWidth(0, 20 * 256);
 
        /**
         * ========================================================
         *                             设置行高度
         *  通过row 对象设置行高
         * ========================================================
         */
        HSSFRow row = sheet.createRow(0);
        //heightInPoints 设置的值永远是height属性值的20倍
        row.setHeightInPoints(20);
 
        HSSFRow row1 = sheet.createRow(5);
        // Set the row's height or set to ff (-1) for undefined/default-height.
        // Set the height in "twips" or
        // 1/20th of a point.
        row1.setHeight((short) (25 * 20));
        
        HSSFCell cell = row.createCell(0);
 
        cell.setCellValue("a1b2c3d4e5f6g7h8i9");
 
        //设置默认宽度、高度值        
        HSSFSheet sheet2 =  wb.createSheet("sheet2");
                
        sheet2.setDefaultColumnWidth(20);
        sheet2.setDefaultRowHeightInPoints(20);
 
                //格式化单元格日期信息
        HSSFDataFormat dataFormat =  wb.createDataFormat();
        short dataformat = dataFormat.getFormat("yyyy-mm-dd HH:MM");
        HSSFCellStyle style = wb.createCellStyle();
        
        
        style.setDataFormat(dataformat);
        
        
        HSSFCell cell2 = sheet2.createRow(0).createCell(0);
        
        cell2.setCellValue(new Date());
        
        cell2.setCellStyle(style);
        
        wb.write(fos);
 
        fos.close();


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Apache POI可以通过调用RowsetHeightInPoints()方法和Sheet的setColumnWidth()方法来精确设置Excel的行高和列宽。 要设置行高,首先需要创建一个Row对象,然后调用setHeightInPoints()方法,传入要设置的高度值。该方法接受以磅为单位的浮点数值,可以使用常见的像素值进行换算。例如,要将行高设置为20像素,可以传入20/0.75的值。 示例代码如下: ``` // 创建工作簿和工作表 Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("Sheet1"); // 创建行并设置行高 Row row = sheet.createRow(0); row.setHeightInPoints(20/0.75f); // 将工作簿写入文件 FileOutputStream fileOut = new FileOutputStream("workbook.xlsx"); workbook.write(fileOut); fileOut.close(); workbook.close(); ``` 要设置列宽,需要先创建一个Sheet对象,然后调用setColumnWidth()方法,传入要设置的列索引和宽度值。宽度值是以字符宽度的256倍为单位的,可以根据实际需求进行换算。例如,要将第一列的宽度设置为10个字符宽度,可以传入10*256的值。 示例代码如下: ``` // 创建工作簿和工作表 Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("Sheet1"); // 设置列宽 sheet.setColumnWidth(0, 10*256); // 将工作簿写入文件 FileOutputStream fileOut = new FileOutputStream("workbook.xlsx"); workbook.write(fileOut); fileOut.close(); workbook.close(); ``` 通过调用上述方法,我们可以在使用Apache POI时精确设置Excel的行高和列宽。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值