java - 使用 getelementsbytagname 进行 XML 过滤

标签 java xml

我正在尝试使用以下程序解析 xml 文件,但想知道为什么 getFirstChild() 在打印时为空白...

nodelist 包含所有 employee 节点,我正在处理每个节点并尝试获取 firstchildlastchild..

xml 文件:

<?xml version="1.0"?>
<Employees>
    <Employee emplid="1111" type="admin">
        <firstname>John</firstname>
        <lastname>Watson</lastname>
        <age>30</age>
        <email>johnwatson@sh.com</email>
    </Employee>
    <Employee emplid="2222" type="admin">
        <firstname>Sherlock</firstname>
        <lastname>Homes</lastname>
        <age>32</age>
        <email>sherlock@sh.com</email>
    </Employee>
</Employees>

java程序:

package XML;


import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import org.xml.sax.SAXException;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
public class XMLTest {

    /**
     * @param args
     */
    public static void main(String[] args) {


        DocumentBuilderFactory builderfactory = DocumentBuilderFactory.newInstance();
        try {
            DocumentBuilder builder = builderfactory.newDocumentBuilder();
            Document xmldocument = builder.parse(new FileInputStream(new File("c:/employees.xml")));
            NodeList node = xmldocument.getElementsByTagName("Employee");
            System.out.println("node length="+node.getLength());
            for (int temp = 0; temp < node.getLength(); temp++){
                System.out.println("First Child = " +node.item(temp).getFirstChild().getNodeValue());
                System.out.println("Last Child = " +node.item(temp).getLastChild().getNodeValue());
            }
        } catch (ParserConfigurationException | SAXException | IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }




    }

}

最佳答案

这很可能是由于列表和元素中作为文本节点出现的空白(空格、制表符、换行符等)造成的。

当使用 java 的 XML DOM 时,我倾向于编写一个像 this 这样的帮助器。因为这很乏味。

关于java - 使用 getelementsbytagname 进行 XML 过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19555015/

相关文章:

java - 如何读取 Google App Engine (JAVA) 中的文件

java - spring mvc - 如何在不创建 View 的情况下从 Controller 检索值

xml - 匹配 xslt 的子字符串模板

java - 如何更改 Android 首选项的外观?

java - 检测到设备正在关闭?

java - 如何在 hibernate 4 中定义获取 session 的事务?

java - 操作栏 - 拖动菜单项

xml - Scala:修改一个NodeSeq

Java 扩展对象(父对象的某些属性除外)

xml - 从不同的 XML 模式映射 XML 数据