forked from fanruan/easyexcel
Jiaju Zhuang
5 years ago
5 changed files with 143 additions and 8 deletions
After Width: | Height: | Size: 4.2 KiB |
@ -0,0 +1,45 @@
|
||||
package com.alibaba.easyexcel.test.demo.write; |
||||
|
||||
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, int relativeRowIndex, boolean isHead) { |
||||
|
||||
} |
||||
|
||||
@Override |
||||
public void afterCellCreate(WriteSheetHolder writeSheetHolder, WriteTableHolder writeTableHolder, CellData cellData, |
||||
Cell cell, Head head, int 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); |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,39 @@
|
||||
package com.alibaba.easyexcel.test.demo.write; |
||||
|
||||
import org.apache.poi.ss.usermodel.DataValidation; |
||||
import org.apache.poi.ss.usermodel.DataValidationConstraint; |
||||
import org.apache.poi.ss.usermodel.DataValidationHelper; |
||||
import org.apache.poi.ss.util.CellRangeAddressList; |
||||
import org.slf4j.Logger; |
||||
import org.slf4j.LoggerFactory; |
||||
|
||||
import com.alibaba.excel.write.handler.SheetWriteHandler; |
||||
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder; |
||||
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder; |
||||
|
||||
/** |
||||
* 自定义拦截器.对第一列第一行和第二行的数据新增下拉框,显示 测试1 测试2 |
||||
* |
||||
* @author Jiaju Zhuang |
||||
*/ |
||||
public class CustomSheetWriteHandler implements SheetWriteHandler { |
||||
|
||||
private static final Logger LOGGER = LoggerFactory.getLogger(CustomSheetWriteHandler.class); |
||||
|
||||
@Override |
||||
public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { |
||||
|
||||
} |
||||
|
||||
@Override |
||||
public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) { |
||||
LOGGER.info("第{}个Sheet写入成功。", writeSheetHolder.getSheetNo()); |
||||
|
||||
// 区间设置 第一列第一行和第二行的数据。由于第一行是头,所以第一、二行的数据实际上是第二三行
|
||||
CellRangeAddressList cellRangeAddressList = new CellRangeAddressList(1, 2, 0, 0); |
||||
DataValidationHelper helper = writeSheetHolder.getSheet().getDataValidationHelper(); |
||||
DataValidationConstraint constraint = helper.createExplicitListConstraint(new String[] {"测试1", "测试2"}); |
||||
DataValidation dataValidation = helper.createValidation(constraint, cellRangeAddressList); |
||||
writeSheetHolder.getSheet().addValidationData(dataValidation); |
||||
} |
||||
} |
Loading…
Reference in new issue