org.dromara.hutool.poi.excel.sax.SheetRidReader Maven / Gradle / Ivy
/*
* Copyright (c) 2013-2024 Hutool Team and hutool.cn
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.dromara.hutool.poi.excel.sax;
import org.dromara.hutool.core.collection.CollUtil;
import org.dromara.hutool.core.collection.ListUtil;
import org.dromara.hutool.core.io.IORuntimeException;
import org.dromara.hutool.core.io.IoUtil;
import org.dromara.hutool.core.text.StrUtil;
import org.dromara.hutool.poi.POIException;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.xml.sax.Attributes;
import org.xml.sax.helpers.DefaultHandler;
import java.io.IOException;
import java.io.InputStream;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
/**
* 在Sax方式读取Excel时,读取sheet标签中sheetId和rid的对应关系,类似于:
*
* <sheet name="Sheet6" sheetId="4" r:id="rId6"/>
*
*
* 读取结果为:
*
*
* {"4": "6"}
*
*
* @author looly
* @since 5.4.4
*/
public class SheetRidReader extends DefaultHandler {
/**
* 从{@link XSSFReader}中解析sheet名、sheet id等相关信息
*
* @param reader {@link XSSFReader}
* @return SheetRidReader
* @since 5.7.17
*/
public static SheetRidReader parse(final XSSFReader reader) {
return new SheetRidReader().read(reader);
}
private final static String TAG_NAME = "sheet";
private final static String RID_ATTR = "r:id";
private final static String SHEET_ID_ATTR = "sheetId";
private final static String NAME_ATTR = "name";
private final Map ID_RID_MAP = new LinkedHashMap<>();
private final Map NAME_RID_MAP = new LinkedHashMap<>();
/**
* 读取Wordkbook的XML中sheet标签中sheetId和rid的对应关系
*
* @param xssfReader XSSF读取器
* @return this
*/
public SheetRidReader read(final XSSFReader xssfReader) {
InputStream workbookData = null;
try {
workbookData = xssfReader.getWorkbookData();
ExcelSaxUtil.readFrom(workbookData, this);
} catch (final InvalidFormatException e) {
throw new POIException(e);
} catch (final IOException e) {
throw new IORuntimeException(e);
} finally {
IoUtil.closeQuietly(workbookData);
}
return this;
}
/**
* 根据sheetId获取rid,从1开始
*
* @param sheetId Sheet的ID,从1开始
* @return rid,从1开始
*/
public Integer getRidBySheetId(final int sheetId) {
return ID_RID_MAP.get(sheetId);
}
/**
* 根据sheetId获取rid,从0开始
*
* @param sheetId Sheet的ID,从0开始
* @return rid,从0开始
* @since 5.5.5
*/
public Integer getRidBySheetIdBase0(final int sheetId) {
final Integer rid = getRidBySheetId(sheetId + 1);
if (null != rid) {
return rid - 1;
}
return null;
}
/**
* 根据sheet name获取rid,从1开始
*
* @param sheetName Sheet的name
* @return rid,从1开始
*/
public Integer getRidByName(final String sheetName) {
return NAME_RID_MAP.get(sheetName);
}
/**
* 根据sheet name获取rid,从0开始
*
* @param sheetName Sheet的name
* @return rid,从0开始
* @since 5.5.5
*/
public Integer getRidByNameBase0(final String sheetName) {
final Integer rid = getRidByName(sheetName);
if (null != rid) {
return rid - 1;
}
return null;
}
/**
* 通过sheet的序号获取rid
*
* @param index 序号,从0开始
* @return rid
* @since 5.5.7
*/
public Integer getRidByIndex(final int index) {
return CollUtil.get(this.NAME_RID_MAP.values(), index);
}
/**
* 通过sheet的序号获取rid
*
* @param index 序号,从0开始
* @return rid,从0开始
* @since 5.5.7
*/
public Integer getRidByIndexBase0(final int index) {
final Integer rid = CollUtil.get(this.NAME_RID_MAP.values(), index);
if (null != rid) {
return rid - 1;
}
return null;
}
/**
* 获取所有sheet名称
*
* @return sheet名称
* @since 5.7.17
*/
public List getSheetNames() {
return ListUtil.of(this.NAME_RID_MAP.keySet());
}
@Override
public void startElement(final String uri, final String localName, final String qName, final Attributes attributes) {
if (TAG_NAME.equalsIgnoreCase(localName)) {
final String ridStr = attributes.getValue(RID_ATTR);
if (StrUtil.isEmpty(ridStr)) {
return;
}
final int rid = Integer.parseInt(StrUtil.removePrefixIgnoreCase(ridStr, Excel07SaxReader.RID_PREFIX));
// sheet名和rid映射
final String name = attributes.getValue(NAME_ATTR);
if (StrUtil.isNotEmpty(name)) {
NAME_RID_MAP.put(name, rid);
}
// sheetId和rid映射
final String sheetIdStr = attributes.getValue(SHEET_ID_ATTR);
if (StrUtil.isNotEmpty(sheetIdStr)) {
ID_RID_MAP.put(Integer.parseInt(sheetIdStr), rid);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy