Java fastCSV实现csv 文件内容的读取和List<Map<String,object>>数据类型生成
时间: 2024-03-13 18:43:36 浏览: 324
Java也有一个叫做fastCSV的库,用于快速读取和生成CSV文件。以下是一个快速的示例,演示如何使用fastCSV读取CSV文件并将其转换为List<Map<String, Object>>数据类型:
```java
import com.opencsv.CSVReader;
import java.io.FileReader;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class CSVReaderExample {
public static void main(String[] args) {
String csvFilePath = "example.csv";
try (CSVReader reader = new CSVReader(new FileReader(csvFilePath))) {
String[] header = reader.readNext(); // 读取csv文件的第一行作为列名
List<Map<String, Object>> data = new ArrayList<>();
String[] row;
while ((row = reader.readNext()) != null) {
Map<String, Object> rowData = new HashMap<>();
for (int i = 0; i < header.length; i++) {
rowData.put(header[i], row[i]);
}
data.add(rowData);
}
System.out.println(data);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
```
这将读取CSV文件,并将其转换为List<Map<String, Object>>类型的数据。其中,List中的每个元素都是一个Map,Map中的键是CSV文件的列名,值是CSV文件中的数据。
如果要生成CSV文件,可以使用以下示例代码:
```java
import com.opencsv.CSVWriter;
import java.io.FileWriter;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
public class CSVWriterExample {
public static void main(String[] args) {
String csvFilePath = "example.csv";
List<Map<String, Object>> data = new ArrayList<>();
Map<String, Object> row1 = new LinkedHashMap<>();
row1.put("Name", "John");
row1.put("Age", 25);
row1.put("Gender", "Male");
data.add(row1);
Map<String, Object> row2 = new LinkedHashMap<>();
row2.put("Name", "Jane");
row2.put("Age", 30);
row2.put("Gender", "Female");
data.add(row2);
Map<String, Object> row3 = new LinkedHashMap<>();
row3.put("Name", "Bob");
row3.put("Age", 40);
row3.put("Gender", "Male");
data.add(row3);
try (CSVWriter writer = new CSVWriter(new FileWriter(csvFilePath))) {
String[] header = {"Name", "Age", "Gender"};
writer.writeNext(header);
for (Map<String, Object> row : data) {
List<String> rowData = new ArrayList<>();
for (String key : header) {
Object value = row.get(key);
rowData.add(value == null ? "" : value.toString());
}
writer.writeNext(rowData.toArray(new String[0]));
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
```
这将生成一个名为example.csv的文件,其中包含data列表中的内容。请注意,使用LinkedHashMap确保列顺序与添加顺序相同。
阅读全文