poi通过设置,固定Excel的行高和列宽

目录

 

1.poi中设置行高

2.poi中设置列宽


1.poi中设置行高

在poi中可以使用HSSFRow.setHeight(short s)方法设置行高:
row.setHeight((short)(12*20));

说明:poi中的行高单位和excel中的行高单位是不一样的,excel中的行高单位是pt(point,磅),而poi中的行高单位则是twips(缇)。
换算公式是:1pt = 20twips

2.poi中设置列宽


POI中Sheet列宽是通过字符个数来确定的,列宽单位为一个字符宽度的1/256
每列可以显示的最大字符数为255。
Sheet sheet = workbook.createSheet(safeSheetName);
sheet.setDefaultColumnWidth(4);
sheet.setColumnWidth(4, 18*256);
sheet.setColumnWidth(5, 18*256);
sheet.setColumnWidth(6, 18*256);
sheet.setColumnWidth(7, 18*256);

其中18对应excel中的单位为:

 

  • 7
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
使用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行高

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋9

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值