簡體   English   中英

轉換列表<Model>列出<String[]>使用 opencsv 寫入 csv 的 Java

[英]Convert List<Model> to List<String[]> Java for write to csv using opencsv

我怎么把這個列表產品

List<GetProductModel> listProduct = new ArrayList<>();

獲取產品模型

private String ProductName,Description,Price; //getter and setter

到這個列表

List<String[]> list = new ArrayList<>();

所以我可以把列表放到

try (CSVWriter writer = new CSVWriter(new FileWriter("c:\\test\\monitor.csv"))) {
        writer.writeAll(list);
    } catch (Exception e) {
        e.printStackTrace();
    }

您可以使用 for 循環或 Streams,例如:

List<String[]> list = listProduct.stream()
                .filter(Objects::nonNull)
                .map(getProductModel -> new String[]{getProductModel.getProductName(), getProductModel.getDescription(), getProductModel.getPrice()})
                .collect(Collectors.toList());
List<GetProductModel> listProduct = new ArrayList<>();

List<String[]> list = new ArrayList<>();

for(GetProductModel x : listProduct) {
    String[] tmpArray = new String[3];
    tmpArray[0] = x.getProductName();
    tmpArray[1] = x.getDescription();
    tmpArray[2] = x.getPrice();
    list.add(tmpArray);
} 

使用 Java 流 API、Lambda 映射和 PrintWriter 寫入 csv:

import com.opencsv.CSVWriter;

import java.io.*;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

public class Main {
    public static void main(String[] args) {
        GetProductModel getProductModel = new GetProductModel();
        getProductModel.setProductName("ProductName");
        getProductModel.setDescription("Description");
        getProductModel.setPrice("Price");

        GetProductModel getProductModel2 = new GetProductModel();
        getProductModel2.setProductName("ProductName2");
        getProductModel2.setDescription("Description2");
        getProductModel2.setPrice("Price2");

        GetProductModel getProductModel3 = new GetProductModel();
        getProductModel3.setProductName("ProductName3");
        getProductModel3.setDescription("Description3");
        getProductModel3.setPrice("Price3");

        List<GetProductModel> getProductModels = new ArrayList<>();
        getProductModels.add(getProductModel);
        getProductModels.add(getProductModel2);
        getProductModels.add(getProductModel3);

        writeToFileUsingPrintWrite(getProductModels);

        writeToFileUsingCSVWriter(getProductModels);
    }

    private static void writeToFileUsingPrintWrite(List<GetProductModel> getProductModels) {
        List<String> productsList = getProductModels
                .stream()
                .map(p -> p.getProductName() + "," + p.getDescription() + "," + p.getPrice())
                .collect(Collectors.toList());

        File csvOutputFile = new File("C:\\products.csv");
        try (
                PrintWriter pw = new PrintWriter(csvOutputFile)) {
            productsList
                    .forEach(pw::println);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
    }

    private static void writeToFileUsingCSVWriter(List<GetProductModel> getProductModels) {
        Iterable<String[]> productsList = getProductModels
                .stream()
                .map(p -> new String[]{p.getProductName(), p.getDescription(), p.getPrice()})
                .collect(Collectors.toList());

        CSVWriter writer;
        try {
            writer = new CSVWriter(new FileWriter("C:\\products_2.csv"));
            writer.writeAll(productsList);
            writer.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM