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 に答える