当我用FixedWidthParser
实例化MultiBeanListProcessor
时,未调用CommonParserSettings#configureFromAnnotations(beanClass)
是因为它不是AbstractBeanProcessor的实例。是否应该为AbstractProcessorBean
中的每个MultiBeanListProcessor
调用该方法?
示例代码:
FixedWidthParserSettings settings = new FixedWidthParserSettings();
settings.setAutoConfigurationEnabled(true);
settings.setHeaderExtractionEnabled(false);
settings.getFormat().setLineSeparator("\n");
MultiBeanListProcessor processor = new MultiBeanListProcessor(FileHeader.class, ...); // FileHeader has an @Headers and fields with @Parsed
settings.setProcessor(processor);
FixedWidthParser parser = new FixedWidthParser(settings); // Here it should call configureFromAnnotations
try (Reader reader = getReader("/positional-file")) {
parser.parse(reader); // the exception is throwed here
} catch (IOException e) {
e.printStackTrace();
}
这是Bean的缩写版本:
import com.univocity.parsers.annotations.FixedWidth;
import com.univocity.parsers.annotations.Headers;
import com.univocity.parsers.annotations.Parsed;
import com.univocity.parsers.fixed.FieldAlignment;
@Headers(sequence = { "bankCode", "batchCode", "registerType" }, extract = false, write = false)
public class FileHeader {
@Parsed
@FixedWidth(value = 3, alignment = FieldAlignment.RIGHT, padding = '0')
private Integer bankCode;
@Parsed
@FixedWidth(value = 4, alignment = FieldAlignment.RIGHT, padding = '0')
private Integer batchCode;
@Parsed
@FixedWidth(value = 1, alignment = FieldAlignment.RIGHT, padding = '0')
private Integer registerType;`
/** getters and setters */
}
例外:
com.univocity.parsers.common.DataProcessingException: Could not find fields [bankCode, bankName, batchCode] in input. Please enable header extraction in the parser settings in order to match field names.
Internal state when error was thrown: line=0, column=0, record=1, charIndex=240
at com.univocity.parsers.common.processor.core.BeanConversionProcessor.mapFieldIndexes(BeanConversionProcessor.java:360)
at com.univocity.parsers.common.processor.core.BeanConversionProcessor.mapValuesToFields(BeanConversionProcessor.java:289)
at com.univocity.parsers.common.processor.core.BeanConversionProcessor.createBean(BeanConversionProcessor.java:457)
at com.univocity.parsers.common.processor.core.AbstractBeanProcessor.rowProcessed(AbstractBeanProcessor.java:51)
at com.univocity.parsers.common.processor.core.AbstractMultiBeanProcessor.rowProcessed(AbstractMultiBeanProcessor.java:101)
at com.univocity.parsers.common.Internal.process(Internal.java:21)
at com.univocity.parsers.common.AbstractParser.rowProcessed(AbstractParser.java:596)
at com.univocity.parsers.common.AbstractParser.parse(AbstractParser.java:132)
context.headers()
中BeanConversionProcessor.mapFieldIndexes
的值为空。还有其他方法可以将
MultiBeanListProcessor
与AutoConfiguration
中的@Headers
一起使用吗?附言:如果将
MultiBeanListProcessor(FileHeader.class)
更改为BeanListProcessor(FileHeader.class)
,它的工作。 最佳答案
在版本2.4.2中修复。 SNAPSHOT版本已修复此问题,目前可通过maven或直接从here获得。
希望这可以帮助