java实现导出带有水印的excel

本文讲述了在Java中如何实现在导出的Excel中添加动态水印的需求,包括实现思路和具体代码实现。作者首先介绍了需求背景,然后讨论了两种方案,最终选择通过创建水印图片并将其绘制到Excel中的方法,以满足业务上每个水印不同的要求。在代码实现部分,展示了创建水印和将水印应用到Excel的步骤。最后,作者提出了优化建议,即预先生成并缓存水印图片,以提高效率。
摘要由CSDN通过智能技术生成

java导出带有水印的excel

起因

最近接到了一个比较恶心的需求,要求在导出的excel中增加水印,并且要求必须是要excel,因为他们要对excel中的数据做操作(既然要操作那水印同样可以删掉,完全是没有用的需求,但是无奈技术做不了主,只能硬着头皮干了)

实现思路

完全没有思路,根本没有相关api,于是百度、谷歌、github查个遍,最有定了方案。
方案有两种:

  1. 先弄好有水印的空excel,然后再往这个excel中写入数据。但是业务要求每个人的水印不同,所以此方案不合适。
  2. 动态生成水印图片在画到生成的excel中。可以满足业务要求,最终决定用此方式。

代码实现

实现很简单,就是先通过createWaterMark方法生成水印图片,在将图片画到所有的sheet中,具体实现如下:

public class ExcelWaterRemarkUtil {

    public static void painWaterMark(Workbook wb,String content) throws IOException {
        String imgFileName = "waterMark_photo_"+content+".png";
        createWaterMark(content,imgFileName);

        int sheetSize = wb.getNumberOfSheets();
        for(int i=0;i<sheetSize;i++){
            Sheet sheet = wb.getSheetAt(i);
            //获取excel实际所占行
            int row = sheet.getFirstRowNum() + sheet.getLastRowNum();
            //获取excel实际所占列
            int cell = sheet.getRow(sheet.getFirstRowNum()).getLastCellNum() + 1;
            //根据行与列计算实际所需多少水印
            putWaterRemarkToExcelNew(wb, sheet, imgFileName, 0, 0, 5, 5, cell / 5 + 1, row / 5 + 1, 0, 0);
        }
    }

    /**
     * 创建水印图片
     * @param content
     * @param file
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值