SelectNodes(“//item“),包括带名字空间节点的获取

SelectNodes("//item")

从任意位置的节点上选择名称为 item 的节点,即整个xml文件的所有名为item的节点。

dom4j.jar

文章是使用dom4j.jar去解析XML文件,如何下载可以自行百度。

代码

import部分(包括不限于)

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.XPath;
import org.dom4j.io.SAXReader;

function1

这个function是解析得到item节点是带Root节点名字空间的。依赖下面的function2

    /**
     * Get all target element with root element's name space from XML file
     * 
     * @param xmlFile need to parse
     * @param targetElement target element name
     * @return all target element
     * @throws DocumentException document exception
     */
    public static List<Element> getAllTargetElementListWithNameSpaceFromXmlFile(File xmlFile, String targetElement) throws DocumentException {
        SAXReader xmlReader = new SAXReader();
        String nameSpace = null;
        try {
            Document doc = xmlReader.read(xmlFile);
            nameSpace = doc.getRootElement().getNamespaceURI();
        } catch (DocumentException e) {
            e.printStackTrace();
            throw e;
        }
        
        return getAllTargetElementListWithNameSpaceFromXmlFile(xmlFile, targetElement, nameSpace);
    }

function2

这个function是解析得到item节点带名字空间。

/**
     * Get all target element with name space from XML file
     * 
     * @param xmlFile need to parse
     * @param targetElement target element name
     * @param nameSpace name space
     * @return all target element
     * @throws DocumentException document exception
     * 
     */
    public static List<Element> getAllTargetElementListWithNameSpaceFromXmlFile(File xmlFile, String targetElement, String nameSpace) throws DocumentException  {
        List<Element> targetElementList = new ArrayList<>();
        SAXReader xmlReader = new SAXReader();
        Document doc = null;
        try {
            doc = xmlReader.read(xmlFile);
        } catch (DocumentException e) {
            e.printStackTrace();
            throw e;
        }
        
        Map<String,String> map = new HashMap<>();
        map.put("xmlns", nameSpace);
        XPath x = (XPath) doc.createXPath("//xmlns:" + targetElement);
        x.setNamespaceURIs(map);
        for(Object obj : x.selectNodes(doc)) {
            targetElementList.add((org.dom4j.Element) obj);
        }
        
        return targetElementList;
    }

function3

这个function是解析得到没有名字空间的item

    /**
     * Get all target element without name space from XML file
     * 
     * @param xmlFile need to parse
     * @param targetElement target element name
     * @return all target element
     * @throws DocumentException document exception
     * 
     */
    public static List<Element> getAllTargetNodeElementListWithoutNameSpaceFromXmlFile(File xmlFile, String targetElement) throws DocumentException {
        List<Element> targetNodeElementList = new ArrayList<>();
        SAXReader xmlReader = new SAXReader();
        try {
            Document doc = xmlReader.read(xmlFile);
            for (Object obj : doc.selectNodes("//" + targetElement)) {
                targetNodeElementList.add((org.dom4j.Element) obj);
            }
        } catch (DocumentException e) {
            e.printStackTrace();
            throw e;
        }
        
        return targetNodeElementList;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用dom4j获取节点的完整路径和对应的行号时,你可以使用XPath表达式和节点的Location Path。 首先,使用XPath表达式来获取节点的完整路径。XPath表达式是一种用于在XML文档中定位节点的语言。在dom4j中,你可以使用`XPath`类来执行XPath表达式。假设你要获取名为`node`的节点的完整路径,可以按照以下步骤进行: 1. 创建一个`Document`对象,表示你的XML文档。假设你的XML文档已经被解析为`Document`对象,并且存储在变量`document`中。 2. 创建一个`XPath`对象,并使用XPath表达式来指定要获取节点。例如,对于名为`node`的节点,可以使用XPath表达式`//node`。 ```java XPath xpath = DocumentHelper.createXPath("//node"); ``` 3. 使用`evaluate()`方法执行XPath表达式,并传入`document`作为参数。这将返回一个节点列表。 ```java List<Node> nodeList = xpath.evaluate(document); ``` 4. 遍历节点列表,并使用`getPath()`方法获取每个节点的完整路径。 ```java for (Node node : nodeList) { String path = node.getPath(); System.out.println("Node path: " + path); } ``` 接下来,获取对应节点的行号。dom4j提供了一个`Dom4jXPath`类,可以在执行XPath表达式时获取节点的行号。你可以按照以下步骤进行: 1. 导入`Dom4jXPath`类。 ```java import org.dom4j.io.Dom4jXPath; ``` 2. 创建一个`Dom4jXPath`对象,并使用XPath表达式来指定要获取节点。例如,对于名为`node`的节点,可以使用XPath表达式`//node`。 ```java Dom4jXPath xpath = new Dom4jXPath("//node"); ``` 3. 使用`setDocument()`方法将`document`对象设置为`Dom4jXPath`对象的文档。 ```java xpath.setDocument(document); ``` 4. 使用`selectNodes()`方法执行XPath表达式,并传入`document`作为参数。这将返回一个节点列表。 ```java List<Node> nodeList = xpath.selectNodes(document); ``` 5. 遍历节点列表,并使用`getLineNumber()`方法获取每个节点的行号。 ```java for (Node node : nodeList) { int lineNumber = node.getLineNumber(); System.out.println("Node line number: " + lineNumber); } ``` 通过以上步骤,你可以使用dom4j获取节点的完整路径和对应的行号。记得替换掉代码中的`//node`为你实际需要获取节点的XPath表达式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值