拆分不带空格的字符串

时间:2014-02-21 10:34:20

标签: java regex string netbeans openvas

我有以下字符串,它由外部程序(OpenVAS)生成并作为字符串成功返回到我的程序。

<create_target_response id="b4c8de55-94d8-4e08-b20e-955f97a714f1" status_text="OK, resource created" status="201"></create_target_response>

我正在尝试拆分字符串给我“b4c8d .... 14f1”而没有引号。我已经尝试了各种各样的转义方法,并继续获取else方法“字符串不包含目标ID”。我已经尝试删除IF语句检查字符串,但继续遇到相同的问题。目标是将我的id字符串放入jTextField6。 String Lob包含如上所示的完整字符串。

     if (Lob.contains("id=\"")){
      // put the split here
           String[] parts = Lob.split("id=\"");
           String cut1 = parts[1];

           String[] part2 = cut1.split("\"");
           String TaskFinal = part2[0];

           jTextField6.setText(TaskFinal);

      }
       else {
           throw new IllegalArgumentException("String does not contain a Target ID");
       }

  } catch (IOException e) {
     e.printStackTrace();
  }

似乎我只需要逃避“而不是=(如果我这样做,Java就会出错)

提前致谢

编辑:现在使用jSoup lib的代码 - 'id'字符串不会显示。有任何想法吗? 感谢

    private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                        
    // TODO add your handling code here:
          String TargIP = jTextField1.getText(); // Get IP Address
          String TargName = jTextField5.getText(); // Get Target Name
          String Vag = "8d32ad99-ac84-4fdc-b196-2b379f861def";
          String Lob = "";

  final String dosCommand = "cmd /c omp -u admin -w admin --xml=\"<create_target><name>" + TargName + "</name><hosts>" + TargIP + "</hosts></create_target>\"";
  3</comment><config id='daba56c8-73ec-11df-a475-002264764cea'/><target id='" + Vag + "'/></create_task>\"";
  final String location = "C:\\";
  try {
     final Process process = Runtime.getRuntime().exec(
        dosCommand + " " + location);
     final InputStream in = process.getInputStream();
     int ch;
     while((ch = in.read()) != -1) {
        System.out.print((char)ch);
       Lob = String.valueOf((char)ch);
       jTextArea2.append(Lob);


     }

  } catch (IOException e) {
     e.printStackTrace();
  }
           String id = Jsoup.parse(Lob).getAllElements().attr("id");
     System.out.println(id); // This doesn't output? 
}

5 个答案:

答案 0 :(得分:1)

这将更轻松地为您提供工作ID:

int idStart = Lob.indexOf("id=")+("id=\"").length();
System.out.println(Lob.substring(idStart,Lob.indexOf("\"",idStart)));

答案 1 :(得分:1)

在“。”的基础上拆分。您可以获得所有关键值。

String str = "<create_target_response id=\"b4c8de55-94d8-4e08-b20e-955f97a714f1\" status_text=\"OK, resource created\" status=\"201\"></create_target_response>";
String[] tokens = str.split("\\\"");
System.out.println(tokens[1]);
System.out.println(tokens[5]);

输出:

b4c8de55-94d8-4e08-b20e-955f97a714f1
201

答案 2 :(得分:0)

在我看来,这比制作它简单得多。首先,在space上拆分,然后检查是否存在=。如果是,split上的=,最后会从第二个令牌中删除"

棘手的一点是""内的空间。这将需要一些正则表达式,您可以从this question处理。

实施例

String input; // Assume this contains the whole string.
String pattern; // Have fun working out the regex.

String[] values = input.split(pattern);

for(String value : values)
{
    if(value.contains("=")) {
        String[] pair = value.split("=");
        String key = pair[0];
        String value = pair[1].replaceAll("\"");

        // Do something with the values.
    }
}

我的方法的优点

如果提供的输入遵循key="value" key="value"的格式,您可以解析通过的任何内容,而不是硬编码属性的名称。

如果这是XML ..

然后使用XML解析器。有一个很好的(很棒的)答案可以解释为什么你不应该使用String操作来解析XML / HTML。 Here就是答案。

答案 3 :(得分:0)

您可以使用正则表达式来提取所需内容;更重要的是,看起来id的值是UUID。因此:

private static final Pattern PATTERN
    = Pattern.compile("\\bid=\"([^\"]+)\"");

// In code...
public String getId(final String input)
{
    final Matcher m = PATTERN.matcher(input);
    if (!m.find())
        throw new IllegalArgumentException("String does not contain a Target ID");
    final String uuid = m.group(1);
    try {
        UUID.fromString(uuid);

    } catch (IllegalArgumentException ignored) {
        throw new IllegalArgumentException("String does not contain a Target ID");
    }

    return uuid;
}

答案 4 :(得分:0)

每个人都在告诉你使用XML解析器(他们是对的),但没有人告诉你如何使用。

这里是:

String lob = ...

使用来自http://jsoup.org的Jsoup,实际上是一个HTML解析器,但也整齐地处理XML:

String id = Jsoup.parse(lob).getAllElements().attr("id");
// b4c8de55-94d8-4e08-b20e-955f97a714f1

使用内置的Java XML API,不那么简洁但没有附加库:

Document dom = DocumentBuilderFactory.newInstance().newDocumentBuilder()
    .parse(new InputSource(new StringReader(lob)));
String id = dom.getDocumentElement().getAttribute("id");
// b4c8de55-94d8-4e08-b20e-955f97a714f1