苦苦挣扎根据分隔符解析不同的文本文件

时间:2013-09-27 17:40:54

标签: java split delimiter

我今天一直在研究这个问题。

这是我的方法,它基本上需要接受.data(txt)文件位置,然后浏览该文本文件的内容并根据存在的分隔符将其分解为字符串。这些是2个文件。 人员档案。

Person ID,First Name,Last Name,Street,City
1,Ola,Hansen,Timoteivn,Sandnes

2,Tove,Svendson,Borgvn,Stavanger
3,Kari,Pettersen,Storgt,Stavanger

订单文件。

Order ID|Order Number|Person ID
10|2000|1
11|2001|2
12|2002|1
13|2003|10


public static void openFile(String url) {
        //initialize array for data to be held
        String[][] myStringArray = new String[10][10];
        int row = 0;
        try {
            //open the file
            FileInputStream fstream = new FileInputStream(url);
            BufferedReader br = new BufferedReader(new InputStreamReader(fstream));
            String strLine;
            //Read File Line By Line
            while ((strLine = br.readLine()) != null) {
                //ignores any blank entries 
                if (!"".equals(strLine)) {
                    //splits by comma(\\| for order) and places individually into array 
                    String[] splitStr = new String[5];
                    //splitStr = strLine.split("\\|");
                    /*
                     * This is the part that i am struggling with getting to work.
                     */

                    if (strLine.contains("\\|")) {
                        splitStr = strLine.split("\\|");
                    } else if (strLine.contains(",")) {
                        splitStr = strLine.split(",");
                    }else{
                        System.out.println("error no delimiter detected");
                    }

                    for (int i = 0; i < splitStr.length; i++) {
                        myStringArray[row][i] = splitStr[i];
                        System.out.println(myStringArray[row][i]);
                    }
                }
            }
            //Close the input stream
            br.close();
        } catch (FileNotFoundException ex) {
            Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
        } catch (IOException ex) {
            Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

正确读取和解析人员文件。但订单文件中带有“|”分隔符没有它。我只是打印'打印'。

令我困惑的是,当我只有splitStr = strLine.split(“\ |”);它工作但我需要这种方法能够检测存在的分隔符,然后应用正确的分割。

非常感谢任何帮助

1 个答案:

答案 0 :(得分:2)

除了应该使用CSV库完成此操作之外,此代码失败的原因是contains不接受正则表达式。删除转义字符,以便检测管道字符

if (strLine.contains("|")) {