簡體   English   中英

使用Java解析Csv文件時出錯

[英]Error Parsing a Csv File with Java

我有一個csv文件,其值如下所示:

1/1/1983;1,7;-3;8;-0,7;84;4;2;11;0;1030;0;0
2/1/1983;2,7;-2;8,4;1,9;94;2;2;15;0;1027;0;0
3/1/1983;4,1;-0,4;11,3;3,1;93;3;3;13;0;1030;0;0
4/1/1983;7,6;1,3;15;5,1;84;9;8;28;0;1027;0;0
5/1/1983;5,6;1,4;10;5,1;97;2;2;11;0;1023;0;0
6/1/1983;7;5,5;7,5;7;100;1;3;9;0;1028;0;0
7/1/1983;7,7;5;13,4;7,1;96;1;4;20;0;1029;0;0
8/1/1983;7,9;7;15,5;7,4;97;2;7;24;0;1029;0;1
9/1/1983;6,7;1;10,3;4,1;83;8;15;44;0;1033;0;0,3
10/1/1983;2,2;-1,9;8;0,4;88;8;4;13;0;1036;0;0
11/1/1983;0,7;-3,4;6,4;-1,2;87;3;1;13;0;1038;0;0
12/1/1983;0,2;-4,7;8;-1,7;87;6;4;9;0;1037;0;0
13/1/1983;1,7;-5,2;11,1;-0,1;88;4;3;15;0;1032;0;

所以我在一個網站上發現了一個Csv Parser實現:

import java.io.File;
import java.io.FileNotFoundException;
import java.util.ArrayList;
import java.util.Scanner;

public class ScannerExample 
{
    public static void main(String[] args) throws FileNotFoundException 
    {
        //Array
        ArrayList<String> weather = new ArrayList<String>();
        //Get scanner instance
        Scanner scanner = new Scanner(new File("C:/csv/meteo2.csv"));

        //Set the delimiter used in file
        scanner.useDelimiter(";");

        //Get all tokens and store them in some data structure
        //I am just printing them
        while (scanner.hasNext()) 
        {
            weather.add(scanner.next());
        }
         System.out.println(weather.get(12));
        //Do not forget to close the scanner  
        scanner.close();
    }
}

但是我對一行最后一個元素連續的行第一個元素有問題:實際上,當我在代碼中嘗試打印第十二個元素時(必須為0)。 它打印

0
2/1/1983

但這只是其中一個要素。 有解決方案嗎?

如果要將分號和換行符用作分隔符,則應使用

scanner.useDelimiter("[;\n]");

Scanner#useDelimiter(String pattern)需要一個正則表達式作為參數。

暫無
暫無

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

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