[XML]在Java中用Document解析XML实例

Document 解析 XML 实例
实例:以下用了三种方式获取 XML 中的标签值
package com.meixin.xml;

import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class XMLParse
{
  Document document = null;

  NodeList allNode = null;

  // 构造函数,初始化Document对象
  public XMLParse()
  {
    // 指定File文件
    File file = new File("MyXml.xml");

    // 建立DocumentBuilderFactory对象
    DocumentBuilderFactory builderFactory = DocumentBuilderFactory
        .newInstance();
    DocumentBuilder builder;
    try
    {
      // 建立DocumentBuilder对象
      builder = builderFactory.newDocumentBuilder();
      // 用DocumentBuilder对象的parse方法引入文件建立Document对象
      document = builder.parse(file);
      allNode = document.getChildNodes();
        
      // 测试1:找出所有person标签,返回NodeList
      NodeList person = document.getElementsByTagName("person");
      // 按条件输出peron标签中的属性和值
      showByCondition(person);

      // 测试2:遍历所有节点
      searchAndShow(allNode);

      // 测试3:按标签名查找输出
      this.SearchByCondition(person);
    }
    catch (ParserConfigurationException e)
    {
      e.printStackTrace();
    }
    catch (SAXException e)
    {
      e.printStackTrace();
    }
    catch (IOException e)
    {
      System.err.println("找不到你指定的文件!");
      e.printStackTrace();
    }
  }

  // 例:寻找遍历
  public void searchAndShow(NodeList allNode)
  {
    System.out.println();
    System.out.println("------searchAndShow输出结果-------");
    for (int i = 0; i < allNode.getLength(); i++)
    {
      // 得到一个节点,需要强制转换为Element,这里Node是Element的父类
      Node node = allNode.item(i);
      if (!node.getNodeName().equals("#text"))
      {
        System.out.println("节点名称:" + node.getNodeName());
      }
      // System.out.println(element.getAttribute(""));

      if (node.getChildNodes().getLength() > 3)
      {
        // 若包含子节点,则递归遍历
        System.out.println("此节点包含子元素!");
        searchAndShow(node.getChildNodes());
      }
      else
      {
        // 若不包含子节点,则输出节点中的内容
        if (!node.getTextContent().trim().equals("")
            && node.getTextContent() != null)
        {
          System.out.println("节点值:" + node.getTextContent());
        }
      }
    }
  }

  // 按条件输出
  public void showByCondition(NodeList allNode)
  {
    System.out.println();
    System.out.println("------showByCondition输出结果-------");
    Element element;
    // 对符合条件的所有节点进行遍历
    for (int i = 0; i < allNode.getLength(); i++)
    {
      // 获得一个元素
      element = (Element) allNode.item(i);
      // 输出这个元素的personid属性
      System.out.println(element.getAttribute("personid"));
      // 此元素有子节点,获取所有子节点,返回一个personList
      NodeList personList = element.getChildNodes();
      // 遍历所有子节点
      for (int j = 0; j < personList.getLength(); j++)
      {
        // 若子节点的名称不为#text,则输出,#text为反/标签
        if (!personList.item(j).getNodeName().equals("#text"))
        {
          // 输出节点名称、节点值
          System.out.println(personList.item(j).getNodeName() + ":"
              + personList.item(j).getTextContent());
        }
      }
    }
  }

  // 按标签名寻找节点
  public void SearchByCondition(NodeList allNode)
  {
    System.out.println();
    System.out.println("------SearchByCondition输出结果-------");
    Element element;
    // 对符合条件的所有节点进行遍历
    for (int i = 0; i < allNode.getLength(); i++)
    {
      // 用document来查找所有name标签,得到一个标签后输出值
      String name = document.getElementsByTagName("name").item(i)
          .getTextContent();
      System.out.println("姓名:" + name);

      // 用document来查找所有tel标签,得到一个标签后输出值
      String tel = document.getElementsByTagName("tel").item(i)
          .getTextContent();
      System.out.println("电话:" + tel);

      // //用document来查找所有tel标签,得到一个标签后输出值
      String sex = document.getElementsByTagName("email").item(i)
          .getTextContent();
      System.out.println("email:" + sex);
      System.out.println("===================");
    }
  }

  public static void main(String[] args)
  {
    new XMLParse();
  }
}
输出结果:
------showByCondition输出结果-------
e01
name:张三
tel:5128
email:[email protected]
e02
name:meixin
tel:5252525
email:[email protected]
e03
name:yu
tel:5389654
email:[email protected]

------searchAndShow输出结果-------
节点名称:people
此节点包含子元素!

------searchAndShow输出结果-------
节点名称:person
此节点包含子元素!

------searchAndShow输出结果-------
节点名称:name
节点值:张三
节点名称:tel
节点值:5128
节点名称:email
节点值:[email protected]
节点名称:person
此节点包含子元素!

------searchAndShow输出结果-------
节点名称:name
节点值:meixin
节点名称:tel
节点值:5252525
节点名称:email
节点值:[email protected]
节点名称:person
此节点包含子元素!

------searchAndShow输出结果-------
节点名称:name
节点值:yu
节点名称:tel
节点值:5389654
节点名称:email
节点值:[email protected]

------SearchByCondition输出结果-------
姓名:张三
电话:5128
email:[email protected]
===================
姓名:meixin
电话:5252525
email:[email protected]
===================
姓名:yu
电话:5389654
email:[email protected]
===================
MyXml.xml 文件内容
<? xml version ="1.0" encoding ="UTF-8" ?>
< people >

   < person personid ="e01" >
     < name >张三 </ name >
     < tel >5128 </ tel >
     < email >[email protected] </ email >
   </ person >
    
   < person personid ="e02" >
     < name >meixin </ name >
     < tel >5252525 </ tel >
     < email >[email protected] </ email >
   </ person >
    
   < person personid ="e03" >
     < name >yu </ name >
     < tel >5389654 </ tel >
     < email >[email protected] </ email >
   </ person >
</ people >
 

本文出自 “wnight88” 博客,谢绝转载!

你可能感兴趣的:(xml,职场,解析xml,休闲,Document解析XML)