You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
2.0 KiB
53 lines
2.0 KiB
package com.alibaba.easyexcel.test.demo.write; |
|
|
|
import java.util.List; |
|
|
|
import org.apache.poi.common.usermodel.HyperlinkType; |
|
import org.apache.poi.ss.usermodel.Cell; |
|
import org.apache.poi.ss.usermodel.CreationHelper; |
|
import org.apache.poi.ss.usermodel.Hyperlink; |
|
import org.apache.poi.ss.usermodel.Row; |
|
import org.slf4j.Logger; |
|
import org.slf4j.LoggerFactory; |
|
|
|
import com.alibaba.excel.metadata.CellData; |
|
import com.alibaba.excel.metadata.Head; |
|
import com.alibaba.excel.write.handler.CellWriteHandler; |
|
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder; |
|
import com.alibaba.excel.write.metadata.holder.WriteTableHolder; |
|
|
|
/** |
|
* 自定义拦截器。对第一行第一列的头超链接到:https://github.com/alibaba/easyexcel |
|
* |
|
* @author Jiaju Zhuang |
|
*/ |
|
public class CustomCellWriteHandler implements CellWriteHandler { |
|
|
|
private static final Logger LOGGER = LoggerFactory.getLogger(CustomCellWriteHandler.class); |
|
|
|
@Override |
|
public void beforeCellCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Row row, |
|
Head head, Integer columnIndex, Integer relativeRowIndex, Boolean isHead) { |
|
|
|
} |
|
|
|
@Override |
|
public void afterCellCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, Cell cell, |
|
Head head, Integer relativeRowIndex, Boolean isHead) { |
|
|
|
} |
|
|
|
@Override |
|
public void afterCellDispose(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, |
|
List<CellData> cellDataList, Cell cell, Head head, Integer relativeRowIndex, Boolean isHead) { |
|
// 这里可以对cell进行任何操作 |
|
LOGGER.info("第{}行,第{}列写入完成。", cell.getRowIndex(), cell.getColumnIndex()); |
|
if (isHead && cell.getColumnIndex() == 0) { |
|
CreationHelper createHelper = writeSheetHolder.getSheet().getWorkbook().getCreationHelper(); |
|
Hyperlink hyperlink = createHelper.createHyperlink(HyperlinkType.URL); |
|
hyperlink.setAddress("https://github.com/alibaba/easyexcel"); |
|
cell.setHyperlink(hyperlink); |
|
} |
|
} |
|
|
|
}
|
|
|