欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java如何读取XML文件 具体实现

程序员文章站 2024-02-18 13:02:04
今天的csdn常见问题来讲解下在java中如何读取xml文件的内容。 直接上代码吧,注释写的很清楚了! 复制代码 代码如下:import java.io.*;impor...

今天的csdn常见问题来讲解下在java中如何读取xml文件的内容。

直接上代码吧,注释写的很清楚了!

复制代码 代码如下:

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 xmlreadertest {

 public static void main(string args[]) {
  element element = null;
  // 可以使用绝对路劲
  file f = new file("test.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();
   // 获得根节点
   system.out.println("根元素:" + element.getnodename());

   // 获得根元素下的子节点
   nodelist childnodes = element.getchildnodes();

   // 遍历这些子节点
   for (int i = 0; i < childnodes.getlength(); i++) {
    // 获得每个对应位置i的结点
    node node1 = childnodes.item(i);
    if ("account".equals(node1.getnodename())) {
     // 如果节点的名称为"account",则输出account元素属性type
     system.out.println("\r\n找到一篇账号. 所属区域: " + node1.getattributes().getnameditem("type").getnodevalue() + ". ");
     // 获得<accounts>下的节点
     nodelist nodedetail = node1.getchildnodes();
     // 遍历<accounts>下的节点
     for (int j = 0; j < nodedetail.getlength(); j++) {
      // 获得<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();
  }
 }
}

然后我们测试的xml文件(test.xml)要放在项目工程的根目录下,其内容是:

复制代码 代码如下:

<?xml version="1.0" encoding="gbk"?>
<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>

直接运行代码,输出:

根元素:accounts

找到一篇账号. 所属区域: type1.
卡号: 100001
密码: 123
姓名: 李四
余额: 1000000.00

找到一篇账号. 所属区域: type2.
卡号: 100002
密码: 123
姓名: 张三
余额: 1000.00