Beispiel für Spring Batch MultiResourceItemReader
In diesem Tutorial zeigen wir Ihnen, wie Sie Elemente aus mehreren Ressourcen (mehreren CSV-Dateien) lesen und in eine einzelne CSV-Datei schreiben.
Verwendete Tools und Bibliotheken
-
Maven 3
-
Eclipse 4.2
-
JDK 1.6
-
Federkern 3.2.2.FREIGABE
-
Spring Batch 2.2.0.RELEASE
P.S This example – 3 CSV files (reader) – combine into a single CSV file (writer).
1. Projektverzeichnisstruktur
Überprüfen Sie die endgültige Projektstruktur, ein Standard-Maven-Projekt.

2. Mehrere CSV-Dateien
Es gibt 3 CSV-Dateien, später werden wirMultiResourceItemReader verwenden, um sie einzeln zu lesen.
csv/inputs/domain-1-3-2013.csv
1,facebook.com 2,yahoo.com 3,google.com
csv/inputs/domain-2-3-2013.csv
200,example.com 300,stackoverflow.com 400,oracle.com
csv/inputs/domain-3-3-2013.csv
999,eclipse.org 888,baidu.com
3. Spring Batch-Jobs
Ein Job zum Lesen von Ressourcen, die diesem Mustercsv/inputs/domain-*.csv entsprechen, und zum Schreiben in eine einzelne Lebenslaufdateidomain.all.csv.
resources/spring/batch/jobs/job-read-files.xml
resources/spring/batch/config/context.xml
4. Starte es
Erstellen Sie eine Java-Klasse und führen Sie den Batch-Job aus.
App.java
package com.example;
import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class App {
public static void main(String[] args) {
App obj = new App();
obj.run();
}
private void run() {
String[] springConfig = { "spring/batch/jobs/job-read-files.xml" };
ApplicationContext context = new ClassPathXmlApplicationContext(springConfig);
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
Job job = (Job) context.getBean("readMultiFileJob");
try {
JobExecution execution = jobLauncher.run(job, new JobParameters());
System.out.println("Exit Status : " + execution.getStatus());
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("Done");
}
}
Ausgabe. Der Inhalt von drei CSV-Dateien wird gelesen und zu einer einzigen CSV-Datei kombiniert.
csv/outputs/domain.all.csv
1,facebook.com 2,yahoo.com 3,google.coms 200,example.com 300,stackoverflow.com 400,oracle.com 999,eclipse.org 888,baidu.com
Quellcode herunterladen
Laden Sie es herunter -SpringBatch-MultiResourceItemReader-Example.zip (12 kb)