ApachePOI导出exce,设置单元格风格的属性和设置字体风格的属性的两个工具类,POI宽度和excel 像素转换

2 篇文章 0 订阅

设置单元格风格的属性和设置字体风格的属性的两个工具类,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;
		}

	}



  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值