超级好用easyexcel插件

通过注解方式完成excel导入导出,性能和效率远超poi插件;

第一步、引入价保,如果是maven项目引入依赖

第二步、excel列和实体类变量绑定

@ExcelProperty()

注解中有三个参数value,index,converter分别代表列明,列序号,数据转换方式

@ColumnWidth(设置列宽)

设置列宽度的注解,注解中只有一个参数value,value的单位是字符长度,最大可以设置255个字符

@ContentStyle(设置内容格式)


dataFormat    日期格式
hidden    设置单元格使用此样式隐藏
locked    设置单元格使用此样式锁定
quotePrefix    在单元格前面增加`符号,数字或公式将以字符串形式展示
horizontalAlignment    设置是否水平居中
wrapped    设置文本是否应换行。将此标志设置为true通过在多行上显示使单元格中所有内容可见
verticalAlignment    设置是否垂直居中
rotation    设置单元格中文本旋转角度。03版本的Excel旋转角度区间为-90° ~ 90°,07版本的Excel旋转角度区间为0°~180°
indent    设置单元格中缩进文本的空格数
borderLeft    设置左边框的样式
borderRight    设置右边框样式
borderTop    设置上边框样式
borderBottom    设置下边框样式
leftBorderColor    设置左边框颜色
rightBorderColor    设置右边框颜色
topBorderColor    设置上边框颜色
bottomBorderColor    设置下边框颜色
fillPatternType    设置填充类型
fillBackgroundColor    设置背景色
fillForegroundColor    设置前景色
shrinkToFit    设置自动单元格自动大小
 

 easyexcel还有许多列表样式的注解

第三步、实现excel导入导出

导入

 

导出

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Java EasyExcel 是一款非常好用的 Excel 操作工具,提供了丰富的 API 接口,可以方便地进行 Excel 文件的读写操作。而在实际应用中,我们可能需要在 Excel 文件中添加一些自定义的水印,以便于区分文件的来源或者保护文件的安全性。本文将介绍如何使用 Java EasyExcel 自定义水印件。 1. 创建水印件类 首先,我们需要创建一个自定义的水印件类,实现 com.alibaba.excel.write.handler.WriteHandler 接口,该接口提供了 beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) 方法,允许我们在生成 Excel 文件之前对 Sheet 进行一些自定义操作。以下是一个简单的水印件类示例: ```java public class WaterMarkHandler implements WriteHandler { private String waterMark; // 水印内容 public WaterMarkHandler(String waterMark) { this.waterMark = waterMark; } @Override public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { Sheet sheet = writeSheetHolder.getSheet(); Drawing<?> drawing = sheet.createDrawingPatriarch(); // 创建水印文本框 ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 0, 10, 10); Textbox textBox = drawing.createTextbox(anchor); // 设置文本框属性 textBox.setLineStyleColor(255, 255, 255); textBox.setFillColor(255, 255, 255); textBox.setVerticalAlignment(VerticalAlignment.CENTER); textBox.setHorizontalAlignment(HorizontalAlignment.CENTER); textBox.setText(new HSSFRichTextString(waterMark)); } @Override public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { // do nothing } } ``` 在上面的代码中,我们通过实现 beforeSheetCreate() 方法,在生成 Sheet 之前创建了一个水印文本框,并设置了文本框的属性和文本内容。 2. 使用水印件 在使用 Java EasyExcel 生成 Excel 文件时,我们可以将上面定义的 WaterMarkHandler 类作为参数传递给 ExcelWriter 的构造函数,从而实现添加自定义水印的功能。以下是一个简单的示例: ```java public void writeExcelWithWaterMark(OutputStream outputStream, List<List<String>> data, String waterMark) throws IOException { ExcelWriter writer = new ExcelWriter(outputStream, ExcelTypeEnum.XLSX); WriteSheet sheet = new WriteSheet(); sheet.setSheetName("Sheet1"); sheet.setClazz(String.class); sheet.setHead(Collections.emptyList()); sheet.setTableStyle(new TableStyle()); sheet.setWriteHandler(new WaterMarkHandler(waterMark)); // 设置水印件 writer.write1(data, sheet); writer.finish(); } ``` 在上面的代码中,我们通过调用 setWriteHandler() 方法将 WaterMarkHandler 对象传递给 WriteSheet,从而在生成 Excel 文件时添加自定义水印。完整的代码实现可以参考下面的示例: ```java import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.metadata.TableStyle; import com.alibaba.excel.metadata.VerticalAlignment; import com.alibaba.excel.metadata.WriteSheet; import com.alibaba.excel.write.handler.WriteHandler; import com.alibaba.excel.write.handler.WriteHandlerHolder; import com.alibaba.excel.write.handler.WriteWorkbookHolder; import com.alibaba.excel.write.handler.context.CellWriteHandlerContext; import com.alibaba.excel.write.handler.context.RowWriteHandlerContext; import com.alibaba.excel.write.handler.context.SheetWriteHandlerContext; import org.apache.poi.hssf.usermodel.HSSFRichTextString; import org.apache.poi.ss.usermodel.HorizontalAlignment; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.VerticalAlignment; import org.apache.poi.ss.usermodel.drawing.ClientAnchor; import org.apache.poi.ss.usermodel.drawing.Drawing; import org.apache.poi.ss.usermodel.drawing.Textbox; import org.apache.poi.ss.util.CellAddress; import java.io.IOException; import java.io.OutputStream; import java.util.Collections; import java.util.List; public class WaterMarkHandler implements WriteHandler { private String waterMark; public WaterMarkHandler(String waterMark) { this.waterMark = waterMark; } @Override public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { Sheet sheet = writeSheetHolder.getSheet(); Drawing<?> drawing = sheet.createDrawingPatriarch(); // 创建水印文本框 ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 0, 10, 10); Textbox textBox = drawing.createTextbox(anchor); // 设置文本框属性 textBox.setLineStyleColor(255, 255, 255); textBox.setFillColor(255, 255, 255); textBox.setVerticalAlignment(VerticalAlignment.CENTER); textBox.setHorizontalAlignment(HorizontalAlignment.CENTER); textBox.setText(new HSSFRichTextString(waterMark)); } @Override public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { // do nothing } public static void writeExcelWithWaterMark(OutputStream outputStream, List<List<String>> data, String waterMark) throws IOException { ExcelWriter writer = new ExcelWriter(outputStream, ExcelTypeEnum.XLSX); WriteSheet sheet = new WriteSheet(); sheet.setSheetName("Sheet1"); sheet.setClazz(String.class); sheet.setHead(Collections.emptyList()); sheet.setTableStyle(new TableStyle()); sheet.setWriteHandler(new WaterMarkHandler(waterMark)); writer.write1(data, sheet); writer.finish(); } } ``` 这样,我们就可以使用 Java EasyExcel 实现自定义水印件的功能了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值