如何在Spring批处理的FlatFileReader中设置分隔符值?

时间:2015-07-10 12:33:57

标签: java spring spring-batch batch-processing

我是春季批次新手。我的任务是开发读取平面文件的代码,其中值由管道" |"分隔。我发现我可以通过FlatFileReader来完成它。但是我没有得到如何在读取期间设置分隔符值以及如何使用我的POJO成员变量映射每个列。

平面文件中的示例值如下。

3345|742|0|N

3346|743|1|A

3347|742|0|N

3348|742|1|C

3345|743|0|K

提前致谢。

2 个答案:

答案 0 :(得分:7)

FlatFileItemReader将每条记录的解析委托给LineTokenizer(通过LineMapper)。我假设您正在使用允许您设置分隔符的DelimitedLineTokenizer(默认值为a)。要使用管道作为分隔符进行配置:

<bean id="reader" class="org.springframework.batch.item.file.FlatFileItemReader">
    <property name="resource" value="<SOME_VALUE>"/>
    <property name="lineMapper">
        <bean class="org.springframework.batch.item.file.mapping.DefaultLineMapper">
            <property name="lineTokenizer">
                <bean class="org.springframework.batch.item.file.transform.DelimitedLineTokenizer">
                    <property name="names" value="<LIST_OF_VALUES>"/>
                    <property name="delimiter" value="|"/>
                </bean>
            </property>
            <property name="fieldSetMapper" ref="myFieldSetMapper"/>
        </bean>
    </property>
</bean>

其中<SOME_VALUE>是要读取的文件的模式,<LIST_OF_VALUES>是分隔文件中的列名列表。

答案 1 :(得分:1)

使用Spring Batch

DelimitedLineTokenizer tokenizer = new DelimitedLineTokenizer();
tokenizer.setDelimiter("|");
tokenizer.setNames(new String[]{"id", "name"});

DefaultLineMapper lineMapper = new DefaultLineMapper<Seller>();
lineMapper.setLineTokenizer(tokenizer);