[英]Splitting a String without spaces
我有以下字符串,它由外部程序(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?
}
这样可以更轻松地获得您的工作ID:
int idStart = Lob.indexOf("id=")+("id=\"").length();
System.out.println(Lob.substring(idStart,Lob.indexOf("\"",idStart)));
在“。”的基础上拆分。您可以获得所有关键值。
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
在我看来,这比制作它简单得多。 首先,拆分space
,然后检查是否存在=
。 如果是,则在=
上split
,最后从第二个令牌中删除"
。
棘手的一点是""
内部的空间。 这将需要一些正则表达式,您可以从这个问题中解决 。
例
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。 这是答案。
您可以使用正则表达式来提取所需内容; 更重要的是,看起来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;
}
每个人都告诉你使用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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.