[英]Spring Batch : How to read footer of CSV file and validation using FlatFileItemReader
[英]Spring Batch empty file using FlatFileItemReader xML
我正在尝试验证输入文件是否为空或有数据。 我正在使用 spring 通过 XML bean 配置批处理,我的实际配置如下:
<!-- READERS -->
<bean id="mgbfItemReader" class="org.springframework.batch.item.file.FlatFileItemReader">
<property name="strict" value="false" />
<!-- Read a file -->
<property name="resource" value="file:///fichtemcomp/datent/#{processDataClass.fileName}" />
<property name="linesToSkip" value="10" />
<property name="encoding" value="UTF-8" />
<!-- Mapper -->
<property name="lineMapper">
<bean class="org.springframework.batch.item.file.mapping.DefaultLineMapper">
<!-- split it -->
<property name="lineTokenizer">
<bean
class="org.springframework.batch.item.file.transform.DelimitedLineTokenizer">
<property name="delimiter" value="|" />
<!-- Valores del layout -->
<property name="names" value="name,secondName,lastName" />
</bean>
</property>
<!-- Wrapper -->
<property name="fieldSetMapper">
<bean class="com.bbva.mgbf.batch.listeners.ScholarItemReader">
</bean>
</property>
</bean>
</property>
</bean>
<!-- END READERS -->
在我的 class Scholar ItemReader 中,我有类似的内容:
@Override
public Map<String, Object> mapFieldSet(FieldSet fieldSet) throws BindException {
LOGGER.info("Reading all items \t {}", fieldSet);
LOGGER.info("FieldCount \t {}", fieldSet.getFieldCount());
Map<String, Object> dataIn = new HashMap<>(65);
if (fieldSet.getFieldCount() > 0 && !fieldSet.readString(0).trim().isEmpty()) {
LOGGER.info("in if ");
for (int i = 0; i < 65; i++) {
String key = "" + i;
String value = fieldSet.readString(i);
dataIn.put(key, value);
}
}else{
dataIn.put("empty", "emptyFile");
}
return dataIn;
}
但它从未进入“else”声明,它只是结束了这个过程。
任何人都知道是否有另一种方法来验证文件是否为空?
fieldSetMapper
在读取器已经读取一行时调用,因此尝试检查映射器中的文件是否为空在此过程中为时已晚。
我正在尝试验证输入文件是否为空或有数据
我会使用预验证 tasklet 步骤来检查文件是否为空。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.