0
我使用String.split()
方法拆分XML元素。 XML元素的格式如下所示:拆分,修剪和分配Java中的数组元素
start:23 |停止:43 |名称:ABC DEF
分割字符串,我想修剪和分配类似以下后:
String[] parts = oneLine.split("\\s*\\|\\s*"); // splits into 3 strings
for (int x = 0; x < parts.length; x++) {
String tmp = parts[0];
if (tmp.startsWith("start:")) {
tmp = tmp.substring("start:".length());
try {
this.begin = Integer.parseInt(tmp);
}
catch (NumberFormatException nfe) {
nfe.printStackTrace();
}
}
else {
System.err.println("Wrong format");
}
String tmp1 = parts[1];
if (tmp1.startsWith("stop:")) {
tmp1 = tmp1.substring("stop:".length());
try {
this.end = Integer.parseInt(tmp1);
}
catch (NumberFormatException nfe) {
nfe.printStackTrace();
}
}
else {
System.err.println("Wrong format"+tmp1);
}
Strint tmp2 = parts[2];
if (tmp2.startsWith("name:")) {
tmp2 = tmp2.substring("name:".length());
try {
this.name = tmp2;
}
catch (NumberFormatException nfe) {
nfe.printStackTrace();
}
}
else {
System.err.println("Wrong format"+tmp2);
}
这将返回一个错误Wrong format
。这是否与作业String tmp1 = parts[0]
有关?
这不回答你的问题,但没有任何意义恕我直言。为什么要使用for循环,然后仅分割零件[0],零件[1]和零件[2]?你可以跳过for循环,还是我错了? –
发布您的完整代码..没有获得使用if-else的目的? – Prateek
而不是'for'循环,你应该更好地检查'parts.length == 3'。此外,如果您需要解析数字,则应将其添加到正则表达式中,而不是同时执行匹配和子字符串操作。 – Sebastian