gpt4 book ai didi

java - 如何在 spring-batch 中将参数从 ItemReader 传递到 ItemProcessor?

转载 作者:行者123 更新时间:2023-12-02 13:16:18 24 4
gpt4 key购买 nike

问题很简单:如何将仅在 ItemReader 中知道的值(例如当前文件名)传递给 ItemProcessor

@Bean
@JobScope
public ItemReader<String> reader(@Value("#{jobParameters['path]}") String path) {
FlatFileItemReader<String> delegate = new FlatFileItemReader<>();
delegate.setLineMapper(new PassThroughLineMapper());

Resource[] res = new PathMatchingResourcePatternResolver().getResources("file:" + path);

MultiResourceItemReader<String> r = new MultiResourceItemReader<>();
r.setResources(res);
r.setDelegate(delegate);
return r;
}

@Bean
public ItemProcessor<String, String> processor() {
return new ItemProcessor<String, String>() {

@Override
public String process(String item) throws Exception {
//TODO I need the filename that is currently processed. HOW?
return null;
}
};
}

最佳答案

为了安全起见,您应该将文件名添加到读取器返回的对象中。为此,您必须实现自己的包装器 Reader。像这样的事情:

public class MyReader {
private MultiResourceItemReader delegatereader;

public MyContainerDto read() {
String line = delegatereader.read();
if (line==null) return null;

Resource currentResource = delegatereader.getCurrentResource();

MyContainerDto container = MyContainerDto();
container.setLine(line);
container.setResourceName(currentResource.getFileName());
return container;
}

...
}

(此代码未经测试,它只是说明了我将采取的方法)

在我的笔记本电脑上,我能够在一秒钟内创建 100 万个对象,因此创建对象所需的额外性能实际上并不会显着影响整体性能。

问题是,读取器读取的项目数量与 block 大小定义的一样多。之后,它将为该 block 中的每个项目调用处理器。因此,在一个 block 内,其中的项目可能是从不同的文件中读取的。因此,除了在阅读器中将行和文件名绑定(bind)在一起之外,没有其他方法。

另请参阅https://blog.codecentric.de/en/2012/03/transactions-in-spring-batch-part-1-the-basics/

关于java - 如何在 spring-batch 中将参数从 ItemReader 传递到 ItemProcessor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43757856/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com