java读取XML的方法

1.DOM 实现方法

xml文件

<?xml version="1.0" encoding="utf-8"?>
<Accounts>
   <Account type="type1">
         <code>100001</code>
         <pass>123</pass>
         <name>张三</name>
         <money>1000000.00</money>
   </Account>
   <Account type="type2">
       <code>100002</code>
       <pass>123</pass>
       <name>李四</name>
       <money>1000.00</money>
    </Account>
</Accounts>

java文件

package dom;

import java.io.*;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Dom {

    public static void main(String arge[]) {

        Element element = null;
        // 可以使用绝对路劲
        File f = new File("dom/book.xml");

        // documentBuilder为抽象不能直接实例化(将XML文件转换为DOM文件)
        DocumentBuilder db = null;
        DocumentBuilderFactory dbf = null;
        try {
            // 返回documentBuilderFactory返回工厂对象
            dbf = DocumentBuilderFactory.newInstance();
            // 返回db对象用documentBuilderFatory对象获得返回documentBuildr对象
            db = dbf.newDocumentBuilder();

            // 得到一个DOM并返回给document对象
            Document dt = db.parse(f);
            // 得到一个elment根元素
            element = dt.getDocumentElement();
            // 输出根元素的name
            System.out.println("根元素:" + element.getNodeName());//Accounts

            // 获得根元素下的子节点
            NodeList childNodes = element.getChildNodes();

            // 遍历根节点下的所有子节点
            for (int i = 0; i < childNodes.getLength(); i++) {//5 #text Account #text Account #text  会把回车算成子节点,实际只有两个子节点
                // 获得每个对应位置i的结点
                Node node1 = childNodes.item(i);
                System.out.println("分别是="+node1.getNodeName());
                if ("Account".equals(node1.getNodeName())) {
                    // 如果节点的名称为"Account",则输出Account元素属性type
                    //NamedNodeMap   nnm = node1.getAttributes()的返回值是NamedNodeMap对象
                    //通过节点名称返回结点对象Node node = getNamedItem("type")
                    //getNodeValue()返回的是xml节点的值
                    System.out.println("\r\n找到一篇账号. 所属区域: "
                            + node1.getAttributes().getNamedItem("type")
                                    .getNodeValue() + ". ");
                    // 获得<Accounts>下的节点
                    NodeList nodeDetail = node1.getChildNodes();
                    // 遍历<Accounts>下的节点
                    for (int j = 0; j < nodeDetail.getLength(); j++) {//9 #text  code  #text  pass #text  name  #text  money #text
                        // 获得<Accounts>元素每一个节点
                        Node detail = nodeDetail.item(j);
                        if ("code".equals(detail.getNodeName())) // 输出code
                            System.out
                                    .println("卡号: " + detail.getTextContent());
                        else if ("pass".equals(detail.getNodeName())) // 输出pass
                            System.out
                                    .println("密码: " + detail.getTextContent());
                        else if ("name".equals(detail.getNodeName())) // 输出name
                            System.out
                                    .println("姓名: " + detail.getTextContent());
                        else if ("money".equals(detail.getNodeName())) // 输出money
                            System.out
                                    .println("余额: " + detail.getTextContent());
                    }
                }

            }
        }

        catch (Exception e) {
            e.printStackTrace();
        }
    }

}

2.DOM4J 实现方法

XML文件

<?xml version="1.0" encoding="UTF-8"?>
  <RESULT>
    <VALUE >
      <NO>A1234</NO>
      <ADDR>河南省郑州市</ADDR>
    </VALUE>
    <VALUE>
      <NO>B1234</NO>
      <ADDR>河南省郑州市二七区</ADDR>
    </VALUE>
</RESULT>

java文件

package dom4J;

import java.io.*;
import java.util.*;
import org.dom4j.*;
import org.dom4j.io.*; 

public class Test {

    public static void main(String arge[]) {

        try {
            File f = new File("dom4J/a.xml");
            SAXReader reader = new SAXReader();
            //得到Document对象
            Document doc = reader.read(f);
            //获得根节点
            Element root = doc.getRootElement();
            Element foo;
            //elementIterator从根节点遍历子节点
            Iterator i = root.elementIterator("VALUE");
            while(i.hasNext()){
            //for (Iterator i = root.elementIterator("VALUE"); i.hasNext();) {
                foo = (Element) i.next();
                //得到节点的内容
                System.out.print("车牌号码:" + foo.elementText("NO"));
                System.out.println("车主地址:" + foo.elementText("ADDR"));
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

3.JDOM实现方法

XML和上面相同,java代码如下

package jdom;

import java.io.File;
import java.util.List;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;

public class Test {
    public static void main(String arge[]) {

        try {
            SAXBuilder builder = new SAXBuilder();
            Document doc = builder.build(new File("jdom/a.xml"));
            Element foo = doc.getRootElement();
            List allChildren = foo.getChildren();
            for (int i = 0; i < allChildren.size(); i++) {
                System.out.print("车牌号码:"
                        + ((Element) allChildren.get(i)).getChild("NO")
                                .getText());
                System.out.println("车主地址:"
                        + ((Element) allChildren.get(i)).getChild("ADDR")
                                .getText());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

注意:2,3方法需要引入相对应的jar包使用

时间: 2024-10-28 13:24:38

java读取XML的方法的相关文章

Java获取路径方法&amp;相对路径读取xml文件方法

Java获取路径方法&相对路径读取xml文件方法 (1).request.getRealPath("/");//不推荐使用获取工程的根路径 (2).request.getRealPath(request.getRequestURI());//获取jsp的路径,这个方法比较好用,可以直接在servlet和jsp中使用 (3).request.getSession().getServletContext().getRealPath("/");//获取工程的根路径

java读取xml文件的三种方法

xml既简单又标准,值得拥有和学习,好多地方都用的到.假设有这么一个book.xml: <?xml version="1.0" encoding="ISO-8859-1"?> <!-- Copyright w3school.com.cn --> <!-- W3School.com.cn bookstore example --> -<bookstore> -<book category="childre

java读取XML文件的四种方式

java读取XML文件的四种方式 Xml代码 <?xml version="1.0" encoding="GB2312"?> <RESULT> <VALUE> <NO>A1234</NO> <ADDR>河南省郑州市</ADDR> </VALUE> <VALUE> <NO>B1234</NO> <ADDR>河南省郑州市二七区&

JAVA读取xml(转)

Java parse XML methods(4) 关键字: xml  1. 介绍   1>DOM(JAXP Crimson解析器)     DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这个层次结构允许开发人员在树中寻找特定信息.分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作.由于它是基于信息层次的,因而DOM被认为是基于树或基于对象的.DOM 以及广义的基于树的处理具有几个优点.首先,由于树在内存中是持久的,因

记录一种读取XML的方法

using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Xml; namespace ConsoleApplication_readxml { class Program { static void Main(string[] args) { string xml

Java读取XML文件(1)

Java读取XML文件(1) ReadXml.java package Read; import java.io.IOException; import java.util.ArrayList; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import

JAVA读取配置文件的方法

目录 JAVA读取配置文件的方法 普通java项目 WEB项目 JAVA读取配置文件的方法 普通java项目 1.classLoader //主要通过当前类的加载器加载classpath下的资源文件,局限是classpath下的 //getResourceAsStream的路径相当于${classpath}/ 参数相对于这个路径来的 Properties properties = new Properties(); InputStream in = PaySupportUtils.class.g

Java读取xml文件的四种方法,及其取得配置文件的方法

xml文件: Xml代码 <?xml version="1.0" encoding="GB2312"?> <RESULT> <VALUE> <NO>A1234</NO> <ADDR>河南省郑州市</ADDR> </VALUE> <VALUE> <NO>B1234</NO> <ADDR>河南省郑州市二七区</ADDR&g

C#读取xml的方法

最近在用C#语言开发项目的时候,客户要求在客户端记住登录的用户名,于是想到了用Xml的形式保存和读取登陆过的用户名的方法来实现. 过程如下 1. 首先,根据我的需求,只需要记住用户名即可,所有我设计的xml文件的格式为: **************************************************************** <?xml version="1.0" encoding="gb2312"?><userID>