java jdom获取xml的所有子节点包括节点里的值 5
<?xmlversion="1.0"encoding="gbk"?><task><personid="001"><zhuce>请直接<ahref="http://www....
<?xml version="1.0" encoding="gbk"?>
<task>
<person id="001">
<zhuce>请直接<a href="http://www.abc.com/" target="_blank">登录</a>或更换邮箱</zhuce>
</person>
</task>
我想获取 person节点里的值 但是输出的是“请直接或更换邮箱” a标签没有输出,估计是当成节点了
怎么把a标签页都输出啊 我想要的结果是 “请直接<a href="http://www.abc.com/" target="_blank">登录</a>或更换邮箱” 就是把person 里的所有都输出 怎么写 我是jdom解析的 谢谢
好吧 找到解决方法了 需要转译 展开
<task>
<person id="001">
<zhuce>请直接<a href="http://www.abc.com/" target="_blank">登录</a>或更换邮箱</zhuce>
</person>
</task>
我想获取 person节点里的值 但是输出的是“请直接或更换邮箱” a标签没有输出,估计是当成节点了
怎么把a标签页都输出啊 我想要的结果是 “请直接<a href="http://www.abc.com/" target="_blank">登录</a>或更换邮箱” 就是把person 里的所有都输出 怎么写 我是jdom解析的 谢谢
好吧 找到解决方法了 需要转译 展开
3个回答
展开全部
给个例子你, 自己去套用就行给你
<?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代码解析:
import java.io.*;
/**
* xml文件解析
* @author young
*
*/
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 XmlExam {
public static void main(String args[]) {
Element element = null;
// 可以使用绝对路劲
File f = new File("xml.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();
}
}
}
推荐于2017-07-06
展开全部
<zhuce> 的内容,最好是转义一下。。。。。。要是不转义,就取<zhuce>节点的xml值
~
~
~
~
~
~
~
~
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2017-07-06
展开全部
XmlNodenode=xmlDoc.SelectSingleNode("/
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询