我正在使用Spring Batch从具有混合列类型的数据库表中提取CSV文件。示例表SQL模式是
[product] [varchar](16) NOT NULL,
[version] [varchar](16) NOT NULL,
[life_1_dob] [date] NOT NULL,
[first_itm_ratio] [decimal](9,6) NOT NULL,
'first_itm_ration'字段的示例数据库列值为
first_itm_ratio
1.050750
0.920000
但我希望我的CSV能够从值中删除尾随零。
first_itm_ratio
1.05075
0.92
我不希望不必为表中的每个特定字段定义格式,而是为该数据类型的所有列设置全局对象特定格式。
我的csvFileWriter bean
<bean id="csvFileWriter" class="org.springframework.batch.item.file.FlatFileItemWriter" scope="step">
<property name="resource" ref="fileResource"/>
<property name="lineAggregator">
<bean class="org.springframework.batch.item.file.transform.DelimitedLineAggregator">
<property name="delimiter">
<util:constant static-field="org.springframework.batch.item.file.transform.DelimitedLineTokenizer.DELIMITER_COMMA"/>
</property>
<property name="fieldExtractor">
<bean class="org.springframework.batch.item.file.transform.PassThroughFieldExtractor" />
</property>
</bean>
</property>
</bean>
答案 0 :(得分:1)
你可以
BigDecimalToStringConverter implements Converter<BigDecimal, String>
以格式化大小数而不会尾随0 ConversionService
(MyConversionService
)并注册到自定义转换器DelimitedLineAggregator
,注入MyConversionService
,覆盖doAggregate()
以使用注入的转化服务格式化字段public class MyConversionService extends DefaultConversionService {
public MyConversionService() {
super();
addConverter(new BigDecimalToStringConverter());
}
}
public class MyFieldLineAggregator<T> extends DelimitedLineAggregator<T> {
private ConversionService cs = new MyConversionService();
public String doAggregate(Object[] fields) {
for(int i = 0;i < fields.length;i++) {
final Object o = fields[i];
if(cs.canConvert(o.getClass(), String.class)) {
fields[i] = cs.convert(o, String.class);
}
}
return super.doAggregate(fields);
}
}