java可视化编辑xml_操纵/编辑现有xml文档的最佳Java Xml解析器

小编典典

使用JDOM,获取InputStream并将其设为Document:

InputStream inputStream = (InputStream)httpURLConnection.getContent();

DocumentBuilderFactory docbf = DocumentBuilderFactory.newInstance();

docbf.setNamespaceAware(true);

DocumentBuilder docbuilder = docbf.newDocumentBuilder();

Document document = docbuilder.parse(inputStream, baseUrl);

那时,您在Java对象中具有XML。做完了 简单。

您既可以使用文档对象和Java API来遍历它,也可以使用XPath,我发现它很容易(一旦我了解了它)。

构建一个XPath对象,这需要一点时间:

public static XPath buildXPath() {

XPathFactory factory = XPathFactory.newInstance();

XPath xpath = factory.newXPath();

xpath.setNamespaceContext(new AtomNamespaceContext());

return xpath;

}

public class AtomNamespaceContext implements NamespaceContext {

public String getNamespaceURI(String prefix) {

if (prefix == null)

throw new NullPointerException("Null prefix");

else if ("a".equals(prefix))

return "http://www.w3.org/2005/Atom";

else if ("app".equals(prefix))

return "http://www.w3.org/2007/app";

else if ("os".equals(prefix))

return "http://a9.com/-/spec/opensearch/1.1/";

else if ("x".equals(prefix))

return "http://www.w3.org/1999/xhtml";

else if ("xml".equals(prefix))

return XMLConstants.XML_NS_URI;

return XMLConstants.NULL_NS_URI;

}

// This method isn't necessary for XPath processing.

public String getPrefix(String uri) {

throw new UnsupportedOperationException();

}

// This method isn't necessary for XPath processing either.

public Iterator getPrefixes(String uri) {

throw new UnsupportedOperationException();

}

}

然后只需使用它(幸运的是)根本不需要太多时间:

return Integer.parseInt(xpath.evaluate("/a:feed/os:totalResults/text()", document));

2020-11-01

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值