我有类似的东西:
String idCodice = cessionarioCommittente.substring(
cessionarioCommittente.indexOf("<IdCodice>") + 10,
cessionarioCommittente.indexOf("</IdCodice>"));
用于提取由cessionarioCommittente
String变量的内容表示的XML文档的标记内的值。
问题是<IdCodice>
字符串中可能不存在cessionarioCommittente
标记。
所以在这种情况下我得到了这个例外:
Exception in thread "main" java.lang.StringIndexOutOfBoundsException: String index out of range: -10
at java.lang.String.substring(String.java:1937)
at it.sistinf.ediwea.fepa.LoadFatturePa.run(LoadFatturePa.java:103)
at it.sistinf.ediwea.fepa.TestLoadFatturePa.main(TestLoadFatturePa.java:18)
如何解决此问题?例如,检查字符串中是否存在此值?
答案 0 :(得分:4)
您可以进行初步检查,以确保您要查找的标签出现在字符串中:
String idCodice = null;
int startTag = cessionarioCommittente.indexOf("<IdCodice>");
int endTag = cessionarioCommittente.indexOf("</IdCodice>");
if (startTag >= 0 && endTag > startTag) {
idCodice = cessionarioCommittente.substring(startTag + 10, endTag);
}
通过将索引存储在变量中,可以避免两次搜索它们。
答案 1 :(得分:2)
如果找不到字符串,String.indexOf()将返回-1。在使用它之前检查返回值是否>> 0。
答案 2 :(得分:1)
您可以按照Eran的建议进行操作,也可以使用contains
方法和三元操作符:
idCodice = (cessionarioCommittente.contains("<IdCodice>") &&cessionarioCommittente.contains("</IdCodice>")) ? cessionarioCommittente.substring(cessionarioCommittente.indexOf("<IdCodice>") + 10, cessionarioCommittente.indexOf("</IdCodice>")):null;
答案 3 :(得分:0)
在执行子字符串之前,您可以使用以下内容:
String idCodice;
if(cessionarioCommittente.indexOf("<IdCodice>") > -1){
idCodice = cessionarioCommittente.substring(cessionarioCommittente.indexOf("<IdCodice>") + 10, cessionarioCommittente.indexOf("</IdCodice>"));
}
使用indexOf或contains搜索字符串时要小心性能问题(注意:contains()方法在内部使用indexOf())。 但我的问题是,为什么你手动解析xml,有很多库有效地这样做。 here!是一个非常简单的例子