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

今天的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

时间: 2024-10-05 09:35:25

Java如何读取XML文件 具体实现_java的相关文章

java遍历读取xml文件内容_java

本文实例讲解了java遍历读取xml文件内容的详细代码,分享给大家供大家参考,具体内容如下 package test; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.util.Iterator; imp

dom4j从jar包中读取xml文件的方法_java

进行封装的时候,我们常常需要用xml来定义一些规范,在单独运行读取的时候当然不会有问题,但这些xml是往往是放在jar包里的,这样一来,这些东西就找不出来了.文中用到的xml定义如下: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?><ACCESOS> <item>  <SOCIO name="adsf">   <NUMERO>00045

关于Java程序读取XML文件的信息

问题描述 总是报Theprocessinginstructiontargetmatching"[xX][mM][lL]"isnotallowed.的错,不知道怎么改?求助!!!importjava.io.FileWriter;importjava.io.IOException;importjava.util.Iterator;importjava.util.List;importorg.dom4j.Document;importorg.dom4j.DocumentException;i

java如何解析/读取xml文件_java

本文实例为大家分享了java解析/读取xml文件的方法,供大家参考,具体内容如下 XML文件 <?xml version="1.0"?> <students> <student> <name>John</name> <grade>B</grade> <age>12</age> </student> <student> <name>Mary<

java实现利用String类的简单方法读取xml文件中某个标签中的内容_java

1.利用String类提供的indexOf()和substring()快速的获得某个文件中的特定内容 public static void main(String[] args) { // 测试某个词出现的位置 String reqMessage = "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>" + "<in>" + "<head&g

分享非常有用的Java程序 (关键代码)(六)---解析/读取XML 文件(重要)

原文:分享非常有用的Java程序 (关键代码)(六)---解析/读取XML 文件(重要) XML文件 <?xml version="1.0"?> <students> <student> <name>John</name> <grade>B</grade> <age>12</age> </student> <student> <name>Mar

java DOM4J 读取XML实例代码_java

下面展示一篇我自己写的一个XML读取测试 复制代码 代码如下: import java.util.Iterator;import java.io.BufferedReader;import java.io.File;import java.io.IOException;import java.io.InputStreamReader;import java.net.MalformedURLException;import org.dom4j.*;import org.dom4j.io.SAXRe

【java开发系列】—— JDOM创建、修改、删除、读取XML文件

有很多中操作XML文件的方法,这里介绍一下JDOM的使用方法和技巧. JDOM下载地址 创建XML文档 XML文件是一种典型的树形文件,每个文档元素都是一个document元素的子节点.而每个子元素都是一个Element对象,对象可以向下包含. 1 因此我们可以通过先创建元素再将元素添加到父元素中,最后将顶层元素添加到根元素中. 2 创建完文档元素后,就可以把元素添加到document对象中,然后写入文件. 主要使用的函数: Element.setAttribute 为元素添加信息 Elemen

Java读取txt文件的方法_java

java读取txt文件内容.可以作如下理解: 首先获得一个文件句柄.File file = new File(); file即为文件句柄.两人之间连通电话网络了.接下来可以开始打电话了. 通过这条线路读取甲方的信息:new FileInputStream(file) 目前这个信息已经读进来内存当中了.接下来需要解读成乙方可以理解的东西 既然你使用了FileInputStream().那么对应的需要使用InputStreamReader()这个方法进行解读刚才装进来内存当中的数据 解读完成后要输出