我今天一直在研究这个问题。
这是我的方法,它基本上需要接受.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(“\ |”);它工作但我需要这种方法能够检测存在的分隔符,然后应用正确的分割。
非常感谢任何帮助
答案 0 :(得分:2)
除了应该使用CSV库完成此操作之外,此代码失败的原因是contains
不接受正则表达式。删除转义字符,以便检测管道字符
if (strLine.contains("|")) {