JAVA解析XML的具体代码

本文介绍了解析XML文件的具体步骤,包括使用Java进行文件操作及DOM解析的过程。文章详细阐述了如何利用DocumentBuilderFactory和DocumentBuilder来解析XML文件,并通过实例演示了如何获取XML中的特定元素及其属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://zhidao.baidu.com/question/215415054.html


<?xml version="1.0" encoding="UTF-8"?>
<schemas>
<define>
<nvs name="CommonNVSet" nwidth="32" vwidth="128"/>
<nvs name="ForNumeric" nwidth="32" vwidth="10"/>
</define>
</schemas>


要解析XML文件,要先得到内容,假设在classpath中,那就是用流的方法。

File f = new File(xmlPath);
// Runtime.getRuntime().exec("chmod 777 "+xmlPath);
if(!f.exists())
f.createNewFile();
FileInputStream fs = new FileInputStream(f);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.parse(f);
得到了stream 后,就可以用来创建结构了。
Document doc = DocumentBuilderFactory.newDocumentBuilder().parse(stream);
这里你已经得到一个org.w3c.dom.Document的对象了。
既然有了Document对象,接下来就是用各种方法读取内容了。
通过doc.getDocumentElement()可以得到<schemas>这个标签。

这里说明一下,在DOM方式中,
所有的元素,包括属性、标签.....都实现了Node接口;
所有的标签都实现了Element接口,你可以直接把Node的对象强制转换为Element的对象。

对Element对象的操作一般有这么两个:
getElementsByTagName(String tagname)
getAttribute(String name)

比如想得到<nvs name="CommonNVSet" nwidth="32" vwidth="128"/>的nwidth。
步骤是这样的
第一步
NodeList defineList = doc.getElementsByTagName("define")
第二步
//遍历defineList,取出nvs,代码太简单,这里就不写了
NodeList nvsList = ...........
第三步:
从NodeList中取出来的是Node,你可以强制转换成Element
Element nvsElement = ........
if(nvsElement.getAttribute("name").equals("CommonNVSet"))//这里已经得到前面指定的标签了。
//接下来你要干嘛,自己写代码就可以了。

具体还有很多的方法,你可以在JDK文档看看下面这些:
org.w3c.dom.Document
org.w3c.dom.Node
org.w3c.dom.ELement
org.w3c.dom.NodeList
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值