2013-10-29 53 views
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]有关?

+0

这不回答你的问题,但没有任何意义恕我直言。为什么要使用for循环,然后仅分割零件[0],零件[1]和零件[2]?你可以跳过for循环,还是我错了? –

+0

发布您的完整代码..没有获得使用if-else的目的? – Prateek

+0

而不是'for'循环,你应该更好地检查'parts.length == 3'。此外,如果您需要解析数字,则应将其添加到正则表达式中,而不是同时执行匹配和子字符串操作。 – Sebastian

回答

0

回答我的问题。

  String[] parts= oneLine.split("\\s*\\|\\s*"); 
    //System.out.println(parts[0]); 
    String tmp=parts[0].substring("start:".length()); 
    this.begin=Integer.parseInt(tmp); 
    String tmp1=parts[1].substring("stop:".length()); 
    this.end=Integer.parseInt(tmp1); 
    String tmp2=parts[2].substring("name:".length()); 
    this.uri=tmp2; 

上面的代码片断解决我的问题