Java读取XML文件的内容
来源:互联网 发布:广州淘宝代运营诈骗 编辑:程序博客网 时间:2024/05/16 12:34
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
阅读全文
0 0
- Java读取XML文件的内容
- java读取XML文件内容的方法
- java读取文件夹里的所有xml文件内容
- java 读取XML文件里的节点内容
- Java 读取xml文件内容程序小结
- java操作XML文件--读取内容
- 读取xml文件内容
- 读取XML文件内容
- 一个读取xml文件内容的类
- c#读取xml文件的节点内容
- 读取xml文件里面的内容
- 一个读取xml文件内容的类
- C#读取XML文件的内容
- java读取xml指定标签的内容
- 读取XML的内容
- 如何读取XML文件内容!
- 如何读取XML文件内容
- Java中DOM读取xml文件中的内容
- 关于定位锚点 返回相应位置的两种方式
- 算法模板——Tarjan算法
- JS组件系列——Bootstrap组件福利篇:几款好用的组件推荐(二)
- JPA Predicate复杂查询排序
- MySQL学习(四)【MySQL应用优化】
- Java读取XML文件的内容
- Windows下使用GetOpt函数使用
- TypeError: __init__() got an unexpected keyword argument 'shape'
- linux 内存管理的slab机制分析
- 数值的整数次方
- 安卓的模板设计模式
- 4.Less混合(mixins)
- mysql数据库中decimal类型详解
- 用系统用户登录Oracle