首页 > 代码库 > dom4j通过 xpath 处理xmlns
dom4j通过 xpath 处理xmlns
xml中含有命名空间后,用普通的xpath只能筛选到根结点
需要在map里加一个xml的namespace
Map map = new HashMap(); map.put("xmlns","http://docbook.org/ns/docbook"); reader.getDocumentFactory().setXPathNamespaceURIs(map); FileInputStream fin = new FileInputStream(new File(absolutePath)); InputStreamReader is = new InputStreamReader(fin,"UTF-8"); Document document = reader.read(is);
然后再装载XML文件
编写xpath时要带要上xmlns
原来是这样写:document.selectNodes("/book/formerAidText/title")
加上xmlns后:document.selectNodes("/xmlns:book/xmlns:formerAidText/xmlns:title")
如果闲麻烦,加个正则替换
public static String fixedXpath(String xpath) { xpath= xpath.replaceAll("/(\\w)", "/"+"xmlns:$1");//replace start with "/" xpath= xpath.replaceAll("^(\\w)", "xmlns:$1"); //replace start with word return xpath; }
dom4j通过 xpath 处理xmlns
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。