乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 如何调整excel中单独一列的列宽-poi excel设置宽度,excel宽度如何设置

如何调整excel中单独一列的列宽-poi excel设置宽度,excel宽度如何设置

作者:乔山办公网日期:

返回目录:excel表格制作


HSSFFont FontWhiteBold = workbook.createFont();//创建字体样式
636f7079e799bee5baa6e79fa5e98193339FontWhiteBold.setFontHeightInPoints((short)10);//设置字体大小
FontWhiteBold.setFontName("meiryo UI");//设置字体
FontWhiteBold.setColor(HSSFColor.WHITE.index);//设置默认字体颜色白色
FontWhiteBold.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

HSSFCellStyle HeaderStyle = (HSSFCellStyle) workbook.createCellStyle();
HeaderStyle.setBorderBottom((short) 1);//设置边框
HeaderStyle.setBorderLeft((short) 1);//设置边框
HeaderStyle.setBorderRight((short) 1);//设置边框
HeaderStyle.setBorderTop((short) 1);//设置边框
HeaderStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//单元格内容居中
HeaderStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//单元格内容垂直居中
HeaderStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);//背景
HeaderStyle.setFillForegroundColor(HSSFColor.ROYAL_BLUE.index);//设置背景色蓝
HeaderStyle.setFont(FontWhiteBold);

EXCEL中并不具备此种功能,只有使用合并单元格啊,具体操作如下:
1、选中要合并的单元格;
2、在选中的范围内单击右键,选“设置单元格格式”;
3、选“对齐”标签,可看到左下有“合并单元格”选项,选中后确定即可。

工具\材料

电脑  Excel软件

方法如下

1、首先打开“Excel”表格。

袭查看大图" class="ikqb_img_alink">

2、在"开始"选项卡的"单元格"选项组中单击"格式"按钮,展开下拉菜单。

3、在下拉菜单中选择"自动调整列宽"命令。

4、在"开始"选项卡下的"对齐方式"选项组中,单击"自动换行按钮",即可实现让选中单元格的数据自动换行。



EXCEL的行高度和列宽度单位是不一样的。
1,EXCEL列高度的单位是磅,Apache POI的行高度单位是缇(twip):e799bee5baa6e997aee7ad94e4b893e5b19e362
1英寸=72磅=25.4毫米=1440缇
1磅=0.353毫米=20缇

POI中的行高=Excel的行高度*20
Excel的行高度=POI中的行高/20

这里顺便把像素的换行方法说一下:
DPI = 1英寸内可显示的像素点个数。通常电脑屏幕是96DPI, IPhone4s的屏幕是326DPI, 普通激光黑白打印机是400DPI

要计算POI行高或者Excel的行高,就先把它行转换到英寸,再乘小DPI就可以得到像素
像素 = (磅/72)*DPI
像素= (Excel的行高度/72)*DPI
像素= (POI中的行高/20/72)*DPI
Excel的行高度=像素/DPI*72
POI中的行高=像素/DPI*72*20
例如在电脑屏幕上, Excel默认行高度为13.5, (13.5/72)*96=18像素,而Excel中也确实显示的就是18像素。

2,EXCEL列宽度的单位是字符个数
(2014-08-18备注:关于Excel的宽度计算的详细介绍在这篇文章Excel的宽度怎么算的?)
在excel2003以上的版本中,可以建立一个空白的xls文档并将第一列宽度拉到10。然后在A1单元格中输入1234567890可以看到单元格正好可以容纳这十个字符。一个字符的宽度是通过测量1234567890这十个字符在默认字体(通常是宋体11号字,视版本可能不同)下的平均宽度得到的。
只要记住一个字符的宽度是8像素 (2013-10-29备注:一个字符的宽度取决于Excel文件中的第一个字体大小,并不一定就是8像素)就可以了。
一个单元格实际的像素宽度还要在 (字符个数 * 默认字符的宽度)的基础上前后各加2个像素的空白边。另外字符之间会叠加一个像素,在计算时也要减去:
(2013-10-29备注:一个字符的边距不一定只是2像素,和字体有关系)
像素 = 2个像素空白 + (字符个数 * 默认字符的宽度) + 2个像素空白 - (字符个数 - 1)
整理一下,公式变成:
像素 = 5 + (字符个数 * (默认字符的宽度 - 1))
代入默认字符宽度8:
像素 = 5 + (字符个数 * 7)

POI中的字符宽度算法是:
double 宽度 = (字符个数 * (字符宽度 - 1) + 5) / (字符宽度 - 1) * 256;
然后再四舍五入成整数。

最后把我写的一个工具类贴上来,方便使用。
public class HSSFUtil {
private static final short TWIPS_PER_PIEXL = 15; //1 Pixel = 1440 TPI / 96 DPI = 15 Twips

public static short pixel2PoiHeight(int pixel) {
return (short) (pixel * TWIPS_PER_PIEXL);
}

public static int poiHeight2Pixel(short height) {
return height / TWIPS_PER_PIEXL;
}

//像素转poi宽度
public static int pixel2PoiWidth(FontInfo fontInfo, int pixel) {
double numChars = pixel2Character(fontInfo, pixel);
numChars *= fontInfo.charWidth;
numChars += fontInfo.spacing;
numChars /= fontInfo.charWidth;
numChars *= 256;
return (int)numChars;
}

//poi宽度转像素
public static int poiWidth2Pixel(FontInfo fontInfo, int poiWidth) {
double numChars = poiWidth2Character(fontInfo, poiWidth);
return character2Piexl(fontInfo, numChars);
}

public static double poiWidth2Character(FontInfo fontInfo, int poiWidth){
double numChars = poiWidth / 256.0 - (fontInfo.spacing * 1.0 / fontInfo.charWidth);
//2位小数
return new BigDecimal(numChars).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}

public static int character2PoiWidth(FontInfo fontInfo, double numChars){
double w = (numChars + (fontInfo.spacing * 1.0 / fontInfo.charWidth)) * 256;
return (int) w;
}

//excel字符转像素
public static int character2Piexl(FontInfo fontInfo, double numChars){
double pixel = fontInfo.charWidth * numChars + fontInfo.spacing;
return (int)pixel;
}

//excel像素转字符
public static double pixel2Character(FontInfo fontInfo, int pixel){
double numChars = (pixel - fontInfo.spacing) * 1.0 / fontInfo.charWidth;
return new BigDecimal(numChars).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
}

//获得工作簿默认字符宽度
public static FontInfo getDefaultCharWidth(Workbook book){
//博客没人气,我已删除此段代码,请自行研究或者留邮箱
}

//获得不同字体的字符边距
private static int getSpacing(int fontHeightInPoints, int charWidth){
//博客没人气,我已删除此段代码,请自行研究或者留邮箱
}
}

相关阅读

关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网