All Downloads are FREE. Search and download functionalities are using the official Maven repository.

cn.hutool.poi.excel.sax.handler.MapRowHandler Maven / Gradle / Ivy

package cn.hutool.poi.excel.sax.handler;

import cn.hutool.core.collection.IterUtil;
import cn.hutool.core.collection.ListUtil;
import cn.hutool.core.convert.Convert;

import java.util.List;
import java.util.Map;

/**
 * Map形式的行处理器
* 将一行数据转换为Map,key为指定行,value为当前行对应位置的值 * * @author looly * @since 5.4.4 */ public abstract class MapRowHandler extends AbstractRowHandler> { /** * 标题所在行(从0开始计数) */ private final int headerRowIndex; /** * 标题行 */ List headerList; /** * 构造 * * @param headerRowIndex 标题所在行(从0开始计数) * @param startRowIndex 读取起始行(包含,从0开始计数) * @param endRowIndex 读取结束行(包含,从0开始计数) */ public MapRowHandler(int headerRowIndex, int startRowIndex, int endRowIndex){ super(startRowIndex, endRowIndex); this.headerRowIndex = headerRowIndex; this.convertFunc = (rowList)-> IterUtil.toMap(headerList, rowList, true); } @Override public void handle(int sheetIndex, long rowIndex, List rowCells) { if (rowIndex == this.headerRowIndex) { this.headerList = ListUtil.unmodifiable(Convert.toList(String.class, rowCells)); return; } super.handle(sheetIndex, rowIndex, rowCells); } }