0

我有一种方法可以从 .csv 文件中获取数据并将其向后放入数组中(第一行位于最后一个数组插槽中)但是我希望 .csv 文件中的第一行不在数组中。我将如何做到这一点?到目前为止,这是我的代码:

public static String[][] parse(String symbol) throws Exception{

    String destination = "C:/"+symbol+"_table.csv"; 

    LineNumberReader lnr = new LineNumberReader(new FileReader(new File(destination)));
    lnr.skip(Long.MAX_VALUE);

    String[][] stock_array = new String[lnr.getLineNumber()][3];

    try{
        BufferedReader br = new BufferedReader(new FileReader(destination));
        String strLine = "";
        StringTokenizer st = null;

        int line = lnr.getLineNumber()-1;

        while((strLine = br.readLine()) != null){           
            st = new StringTokenizer(strLine, ",");

            while(st.hasMoreTokens()){                  
                stock_array[line][0] = st.nextToken();
                        st.nextToken();
                stock_array[line][1] = st.nextToken();
                stock_array[line][2] = st.nextToken();
                        st.nextToken();
                        st.nextToken();
                        st.nextToken();
            }
            line--; 
        }
    }
    catch(Exception e){
        System.out.println("Error while reading csv file: " + e);
    }
    return stock_array;
}
4

2 回答 2

2

您可以通过阅读第一行而不做任何事情来跳过第一行。在您的 while 循环之前执行此操作:

br.readLine();

为了确保您的数组大小正确并且行存储在正确的位置,您还应该进行以下更改:

String[][] stock_array = new String[lnr.getLineNumber()-1][3];
...
int line = lnr.getLineNumber()-2;
于 2012-01-03T22:54:28.007 回答
1

据我所知,您的代码效率不高。此外,您正在使用 linenumberreader.skip(long.max_value),这不是查找文件行数的正确/确认方法。StringTokenizer 是一种不推荐使用的拆分令牌的方式。我会按以下方式对其进行编码:

public static List<String[]> parse(String symbol) throws Exception {
        String destination = "C:/"+symbol+"_table.csv";
        List<String[]> lines = new ArrayList<String[]>();

        try{
            BufferedReader br = new BufferedReader(new FileReader(destination));
            int index = 0;

            while((line = br.readLine()) != null){
                if(index == 0) {
                   index++;
                   continue; //skip first line
                }

                lines.add(line.split(","));
            }

            if(lines != null && !lines.isEmpty()) {
                Collections.reverse(lines);
            }
        } catch(IOException ioe){
            //IOException Handling
        } catch(Exception e){
            //Exception Handling
        }

        return lines;
    }
于 2012-01-03T23:37:58.347 回答