EasyExcel,合并单元格,设置单元格样式,字体大小

合并单元格

OnceAbsoluteMergeStrategy onceAbsoluteMergeStrategy2 = new OnceAbsoluteMergeStrategy(detail.size() + 1, detail.size() + 1, 0, 4);
//这里一共有4个数字
//第一个数字表示从第几行开始
//第二个数字表示从第几行结束
//第三个数字表示从第几列开始
//第四个数字表示从第几列结束
//这样就可以随意搭配,随意合并了。(索引从0开始)
//我这里表示的含义是,我的表格有2行表头,分别有5列
//我希望最一行合并,数据是动态的,所以是detail.size() + 1
//我只需要合并这一行,所以第二个参数也为detail.size() + 1

设置好上面的以后就把他放入在.registerWriteHandler属性中

OnceAbsoluteMergeStrategy onceAbsoluteMergeStrategy = new OnceAbsoluteMergeStrategy(excels.size() + 1, excels.size() + 1, 0, 4);
        
EasyExcel.write(out, DeptSummaryExcel.class)
        .sheet("科室汇总查询")
        .registerWriteHandler(new SimpleColumnWidthStyleStrategy(25))
        .registerWriteHandler(ExcelUtil.writeCenterStyle())
        .registerWriteHandler(onceAbsoluteMergeStrategy)
        .doWrite(excels);

上面的代码中有个ExcelUtil.writeCenterStyle()这里是设置的他的一些单元格样式

public static HorizontalCellStyleStrategy writeCenterStyle(){
		// 内容的策略
		WriteCellStyle contentWriteCellStyle = new WriteCellStyle();
		//设置 自动换行
		contentWriteCellStyle.setWrapped(true);
		//设置 垂直居中
		contentWriteCellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
		//设置 水平居中
		contentWriteCellStyle.setHorizontalAlignment(HorizontalAlignment.CENTER);
		//设置边框样式
		contentWriteCellStyle.setBorderLeft(BorderStyle.THIN);//细实线
		contentWriteCellStyle.setBorderTop(BorderStyle.THIN);
		contentWriteCellStyle.setBorderRight(BorderStyle.THIN);
		contentWriteCellStyle.setBorderBottom(BorderStyle.THIN);

		WriteFont bodyWriteFont = new WriteFont();
		bodyWriteFont.setFontHeightInPoints((short)12);				// 设置字体大小为20
		//headWriteFont.setItalic(BooleanEnum.TRUE.getBooleanValue());// 设置字体斜体
		contentWriteCellStyle.setWriteFont(bodyWriteFont);
		//contentWriteCellStyle
		// 头部
		WriteCellStyle headWriteCellStyle = new WriteCellStyle();
		// 设置字体居中
		headWriteCellStyle.setHorizontalAlignment(HorizontalAlignment.CENTER);
		WriteFont headWriteFont = new WriteFont();
		headWriteFont.setFontHeightInPoints((short)15);				// 设置字体大小为20
		//headWriteFont.setItalic(BooleanEnum.TRUE.getBooleanValue());// 设置字体斜体
		headWriteCellStyle.setWriteFont(headWriteFont);

		return new HorizontalCellStyleStrategy(headWriteCellStyle, contentWriteCellStyle);
	}
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值