使用毫米或厘米表示Excel的行高和列宽单位

align="right" marginwidth="0" marginheight="0" src="http://sinaggadqg.googlegroups.com/web/NewGoogleBlue.html?gda=QVQF_kMAAAD8hsGaKON9rvrqVWpRQ0yFR9DYEYnS6p1qPgjRTX2SBGG1qiJ7UbTIup-M2XPURDREwKy6qIHiIHsiQYKPAHycuUF_SYovNIKBh6rOeo0tEQ" frameborder="0" width="336" scrolling="no" height="280">

1.Excel的行高和列宽单位无法用mm或cm表示。需要计算。在1024*768下,1CM约为38像素。以此为基准,可计算并控制报表的行列位置。
行高是以磅为单位
1mm=2.835磅

2.Excel行高所使用单位为磅(1cm=28.6磅),列宽使用单位为1/10英寸(既1个单位为2.54mm)
excel里的单位和cm(厘米)可以这样转换:
行高: 1毫米=2.7682个单位 1厘米=27.682个单位 1个单位=0.3612毫米
列宽: 1毫米=0.4374个单位 1厘米=4.374 个单位 1个单位=2.2862毫米


3.列宽与EXCEL的标准字体有关
=====================
"帮助"中说-------
出现在“标准列宽”框中的数字为适合于单元格的标准字体的数字 0-9 的平均值。
=====================
注解:
标准字体------是指EXCEL---工具---选项---常规中的标准字体(当然与字大小也有关)
因为字体中,如,0与1其宽度有可能不一样,EXCEL是以"标准字体"的0123456789这10个字符的平均值为计量单位.
1 个单位列宽为多少磅可用VBA得到。
=Range("A1").Width/Columns(1).ColumnWidth
(当然A1不能是合并了的单元格)
如:
简体OFFICE,默认标准字体(宋体12号)情况下
Range("A1").Width/Columns(1).ColumnWidth=6.444
这样行高为56.7,列宽为8.799时,为2*2CM 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Apache POI可以通过调用Row的setHeightInPoints()方法和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、付费专栏及课程。

余额充值