ExcelReaderBuilder.java 6.6 KB
Newer Older
Z
zhuangjiaju 已提交
1 2
package com.alibaba.excel.read.builder;

3 4
import java.io.File;
import java.io.InputStream;
5 6
import java.util.HashSet;
import java.util.List;
7

庄家钜's avatar
庄家钜 已提交
8 9
import javax.xml.parsers.SAXParserFactory;

10 11
import com.alibaba.excel.ExcelReader;
import com.alibaba.excel.cache.ReadCache;
庄家钜's avatar
庄家钜 已提交
12
import com.alibaba.excel.cache.selector.ReadCacheSelector;
13
import com.alibaba.excel.context.AnalysisContext;
14
import com.alibaba.excel.enums.CellExtraTypeEnum;
15
import com.alibaba.excel.event.AnalysisEventListener;
16
import com.alibaba.excel.event.SyncReadListener;
17
import com.alibaba.excel.read.listener.ModelBuildEventListener;
18 19
import com.alibaba.excel.read.metadata.ReadWorkbook;
import com.alibaba.excel.support.ExcelTypeEnum;
Z
zhuangjiaju 已提交
20 21 22

/**
 * Build ExcelWriter
Z
zhuangjiaju 已提交
23
 *
Z
zhuangjiaju 已提交
24
 * @author Jiaju Zhuang
Z
zhuangjiaju 已提交
25
 */
26
public class ExcelReaderBuilder extends AbstractExcelReaderParameterBuilder<ExcelReaderBuilder, ReadWorkbook> {
Z
zhuangjiaju 已提交
27 28 29
    /**
     * Workbook
     */
30
    private ReadWorkbook readWorkbook;
Z
zhuangjiaju 已提交
31 32

    public ExcelReaderBuilder() {
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
        this.readWorkbook = new ReadWorkbook();
    }

    public ExcelReaderBuilder excelType(ExcelTypeEnum excelType) {
        readWorkbook.setExcelType(excelType);
        return this;
    }

    /**
     * Read InputStream
     * <p>
     * If 'inputStream' and 'file' all not empty,file first
     */
    public ExcelReaderBuilder file(InputStream inputStream) {
        readWorkbook.setInputStream(inputStream);
        return this;
    }

    /**
     * Read file
     * <p>
     * If 'inputStream' and 'file' all not empty,file first
     */
    public ExcelReaderBuilder file(File file) {
        readWorkbook.setFile(file);
        return this;
    }

    /**
     * Read file
     * <p>
     * If 'inputStream' and 'file' all not empty,file first
     */
    public ExcelReaderBuilder file(String pathName) {
        return file(new File(pathName));
    }

    /**
     * Mandatory use 'inputStream' .Default is false.
罗成 已提交
72 73
     * <p>
     * if false,Will transfer 'inputStream' to temporary files to improve efficiency
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
     */
    public ExcelReaderBuilder mandatoryUseInputStream(Boolean mandatoryUseInputStream) {
        readWorkbook.setMandatoryUseInputStream(mandatoryUseInputStream);
        return this;
    }

    /**
     * Default true
     *
     * @param autoCloseStream
     * @return
     */
    public ExcelReaderBuilder autoCloseStream(Boolean autoCloseStream) {
        readWorkbook.setAutoCloseStream(autoCloseStream);
        return this;
    }

庄家钜's avatar
庄家钜 已提交
91 92 93 94 95 96 97 98 99 100 101
    /**
     * Ignore empty rows.Default is true.
     *
     * @param ignoreEmptyRow
     * @return
     */
    public ExcelReaderBuilder ignoreEmptyRow(Boolean ignoreEmptyRow) {
        readWorkbook.setIgnoreEmptyRow(ignoreEmptyRow);
        return this;
    }

102 103 104
    /**
     * This object can be read in the Listener {@link AnalysisEventListener#invoke(Object, AnalysisContext)}
     * {@link AnalysisContext#getCustom()}
Z
zhuangjiaju 已提交
105
     *
106 107 108 109 110 111 112 113 114
     * @param customObject
     * @return
     */
    public ExcelReaderBuilder customObject(Object customObject) {
        readWorkbook.setCustomObject(customObject);
        return this;
    }

    /**
庄家钜's avatar
庄家钜 已提交
115
     * A cache that stores temp data to save memory.
Z
zhuangjiaju 已提交
116
     *
117 118 119 120 121 122 123 124
     * @param readCache
     * @return
     */
    public ExcelReaderBuilder readCache(ReadCache readCache) {
        readWorkbook.setReadCache(readCache);
        return this;
    }

庄家钜's avatar
庄家钜 已提交
125 126 127 128 129 130 131 132 133 134 135
    /**
     * Select the cache.Default use {@link com.alibaba.excel.cache.selector.SimpleReadCacheSelector}
     *
     * @param readCacheSelector
     * @return
     */
    public ExcelReaderBuilder readCacheSelector(ReadCacheSelector readCacheSelector) {
        readWorkbook.setReadCacheSelector(readCacheSelector);
        return this;
    }

庄家钜's avatar
庄家钜 已提交
136 137 138 139 140 141 142 143 144 145 146
    /**
     * Whether the encryption
     *
     * @param password
     * @return
     */
    public ExcelReaderBuilder password(String password) {
        readWorkbook.setPassword(password);
        return this;
    }

庄家钜's avatar
庄家钜 已提交
147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
    /**
     * SAXParserFactory used when reading xlsx.
     * <p>
     * The default will automatically find.
     * <p>
     * Please pass in the name of a class ,like : "com.sun.org.apache.xerces.internal.jaxp.SAXParserFactoryImpl"
     *
     * @see SAXParserFactory#newInstance()
     * @see SAXParserFactory#newInstance(String, ClassLoader)
     * @param xlsxSAXParserFactoryName
     * @return
     */
    public ExcelReaderBuilder xlsxSAXParserFactoryName(String xlsxSAXParserFactoryName) {
        readWorkbook.setXlsxSAXParserFactoryName(xlsxSAXParserFactoryName);
        return this;
    }

164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
    /**
     * Read some extra information, not by default
     *
     * @param extraType
     *            extra information type
     * @return
     */
    public ExcelReaderBuilder extraRead(CellExtraTypeEnum extraType) {
        if (readWorkbook.getExtraReadSet() == null) {
            readWorkbook.setExtraReadSet(new HashSet<CellExtraTypeEnum>());
        }
        readWorkbook.getExtraReadSet().add(extraType);
        return this;
    }

179 180 181 182 183 184 185 186 187 188 189 190 191
    /**
     * Whether to use the default listener, which is used by default.
     * <p>
     * The {@link ModelBuildEventListener} is loaded by default to convert the object.
     *
     * @param useDefaultListener
     * @return
     */
    public ExcelReaderBuilder useDefaultListener(Boolean useDefaultListener) {
        readWorkbook.setUseDefaultListener(useDefaultListener);
        return this;
    }

192 193 194 195
    public ExcelReader build() {
        return new ExcelReader(readWorkbook);
    }

196 197 198 199 200 201 202 203 204 205 206 207 208 209
    public void doReadAll() {
        ExcelReader excelReader = build();
        excelReader.readAll();
        excelReader.finish();
    }

    /**
     * Synchronous reads return results
     *
     * @return
     */
    public <T> List<T> doReadAllSync() {
        SyncReadListener syncReadListener = new SyncReadListener();
        registerReadListener(syncReadListener);
庄家钜's avatar
庄家钜 已提交
210
        ExcelReader excelReader = build();
庄家钜's avatar
庄家钜 已提交
211 212
        excelReader.readAll();
        excelReader.finish();
213
        return (List<T>)syncReadListener.getList();
庄家钜's avatar
庄家钜 已提交
214 215
    }

216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237
    public ExcelReaderSheetBuilder sheet() {
        return sheet(null, null);
    }

    public ExcelReaderSheetBuilder sheet(Integer sheetNo) {
        return sheet(sheetNo, null);
    }

    public ExcelReaderSheetBuilder sheet(String sheetName) {
        return sheet(null, sheetName);
    }

    public ExcelReaderSheetBuilder sheet(Integer sheetNo, String sheetName) {
        ExcelReaderSheetBuilder excelReaderSheetBuilder = new ExcelReaderSheetBuilder(build());
        if (sheetNo != null) {
            excelReaderSheetBuilder.sheetNo(sheetNo);
        }
        if (sheetName != null) {
            excelReaderSheetBuilder.sheetName(sheetName);
        }
        return excelReaderSheetBuilder;
    }
238 239 240 241 242

    @Override
    protected ReadWorkbook parameter() {
        return readWorkbook;
    }
Z
zhuangjiaju 已提交
243
}