簡體   English   中英

如何使用傑克遜圖書館(Jackson Library)讀取Java中的CSV文件

[英]How to Read CSV file in java using Jackson Library ,JSON

如何使用Jackson庫從Java中的路徑讀取CSV文件。 並使用CsvSchemaObjectReaderCsvMapper進行解析 然后使用Jackson庫將其轉換為JSON對象。 請幫忙。

private void testCsvRead() throws Exception 
 {
   String FILE_NAME = "G://Read folder/output.csv";
   System.out.println("read csv");

   ClassLoader classLoader = getClass().getClassLoader();

   //-------------*****I am getting error here*****------------///

   File file = new File(classLoader.getResource(FILE_NAME).getFile());

   <-------------**********------------/
   CsvSchema schema = CsvSchema.builder().addColumn("parentCategoryCode").addColumn("code").addColumn("name").addColumn("description").build();
   CsvMapper mapper = new CsvMapper();


   ObjectReader oReader = mapper.readerFor(OfferTemplateCategory.class).with(schema);


   try (Reader reader = new FileReader(file)) {
    MappingIterator mi = oReader.readValues(reader);

       while (mi.hasNext()) 
       {
         System.out.println(mi.next());
       }

  }
}

我在這條線上出現錯誤(見上文)

File file = new File(classLoader.getResource(FILE_NAME).getFile());

這是錯誤--->

java.lang.NullPointerException
at CSVtester.CsvTest.testCsvRead(CsvTest.java:39)
at CSVtester.CsvTest.main(CsvTest.java:26)

這里可能的問題是classLoader.getResource(FILE_NAME)返回null

當您使用文件的絕對路徑時,您可能希望簡化代碼並僅使用:

File file = new File("G://Read folder/output.csv");

您可以通過在File對象上調用exists()來驗證文件是否存在。

注意

這是Classloader#getResourceAPI ,並可能解釋為什么您的情況為null

暫無
暫無

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

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