设置单元格风格的属性和设置字体风格的属性的两个工具类,POI宽度和excel 像素转换
/**
* 功能:设置单元格风格的属性
* */
public static HSSFCellStyle SetCellStyleAttribute(int stylenum,
HSSFCellStyle style, HSSFFont font) {
switch (stylenum) {
// 单元格格式一:水平居中,垂直居中
case 1:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setFont(font);
break;
// 单元格格式二:水平居中,垂直居中,有边框
case 2:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 下边框
style.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
style.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
style.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
style.setFont(font);
break;
// 单元格格式三:垂直居中
case 3:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setFont(font);
break;
default:
break;
}
return style;
}
/**
* 设置字体风格的属性
* */
public static void setFontStyleAttribute(int fontnum, HSSFFont font) {
font.setColor(HSSFColor.BLACK.index);
switch (fontnum) {
case 1:// 字体风格:微软雅黑,12号字体,黑色,加粗
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
break;
case 2:// 字体风格:微软雅黑,10号字体,黑色
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 10);
break;
case 3:// 字体风格:微软雅黑,9号字体,黑色
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 9);
break;
case 4:// 字体风格:宋体,12号字体,黑色,加粗
font.setFontName("宋体");
font.setFontHeightInPoints((short) 12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
break;
case 5:// 字体风格:宋体,10号字体,黑色
font.setFontName("宋体");
font.setFontHeightInPoints((short) 10);
break;
case 6:// 字体风格:宋体,9号字体,黑色
font.setFontName("宋体");
font.setFontHeightInPoints((short) 9);
break;
default:
break;
}
}
public static int getPOIWidthByExcelPiex(int Piex) {
return (int) (Piex * 37.04);
}
/**
* 功能:设置2007以及以上版本单元格风格的属性
* */
public static CellStyle SetXCellStyleAttribute(int stylenum,
CellStyle style, Font font) {
switch (stylenum) {
// 单元格格式一:水平居中,垂直居中
case 1:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setFont(font);
break;
// 单元格格式二:水平居中,垂直居中,有边框
case 2:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
style.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 下边框
style.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
style.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
style.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
style.setFont(font);
break;
// 单元格格式三:垂直居中
case 3:
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
style.setFont(font);
break;
default:
break;
}
return style;
}
/**
* 设置2007以及以上版本字体风格的属性
* */
public static void setXFontStyleAttribute(int fontnum, Font font) {
font.setColor(HSSFColor.BLACK.index);
switch (fontnum) {
case 1:// 字体风格:微软雅黑,12号字体,黑色,加粗
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
break;
case 2:// 字体风格:微软雅黑,10号字体,黑色
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 10);
break;
case 3:// 字体风格:微软雅黑,9号字体,黑色
font.setFontName("微软雅黑");
font.setFontHeightInPoints((short) 9);
break;
case 4:// 字体风格:宋体,12号字体,黑色,加粗
font.setFontName("宋体");
font.setFontHeightInPoints((short) 12);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
break;
case 5:// 字体风格:宋体,10号字体,黑色
font.setFontName("宋体");
font.setFontHeightInPoints((short) 10);
break;
case 6:// 字体风格:宋体,9号字体,黑色
font.setFontName("宋体");
font.setFontHeightInPoints((short) 9);
break;
default:
break;
}
}