Document doc=........;
Element root=doc.getDocumentElement();
Element nameNode=(Element)root.getElementsByTagName_r(name).item(0);
String name=nameNode.getNodeValue();
通过这种方式得到的
name
值为
null
。
网络上也给出了解决方案
String name=nameNode.getFirstChild().getNodeValue()
这样我们就可以得到
admin
了。问题解决!可是为什么呢?
凡事多问个为什么
我们需要解决两个问题:这个
null
是哪里来的?怎么获得
admin
这个文本呢?
网友也给出了答案:在Node接口的官方文档中有详细解释(参考API文档)。
可以看出:
Element
的nodeValue是null(问题的根源被找到了),
Text
的nodeValue是该文本节点的内容。
在说明这个问题之前,我们首先要了解两个接口
Element
和
Text
。
这里我们知道
Text
是用来表示
Element
或
Attr
的文本内容(在XML中是字符数据)。
在demo.xml中
name
节点是
ELement
的一个实例(我们暂且可以这么理解),而我们想要得到的
admin
是
Text
的一个实例。这一点我们也可以通过获取NodeType来证实。
int nameType=nameNode.getNodeType();
int textType=nameNode.getFirstChild().getNodeType();
这就是说admin(
Text
)节点是name(
ELement
)的子节点,这也是为什么我们可以通过nameNode.getFirstChild().getNodeValue()来获取admin这个文本节点(值)。
回归本源,凡事是为了什么
然而事情并没有结束,回到我们最初的问题。
说了这么多我们的目的也就是为了获取admin。
String name=nameNode.getTextContent();
到这里圆满结束。
站在巨人的肩膀
参考资料:
http://blog.sina.com.cn/s/blog_5da93c8f0100t28h.html
Ajax应用中很常见的行为便是后台把数据用XML包裹好返回给浏览器,浏览器解析XML,得到
node
Value
如果单个
node
中内容很长(超过4096字节),这时在FireFox/Mozilla中就要注意了,内容将会被FrieFox分解为多个text
Node
,每个大小为4096字节。这种情况可以用下列函数处理(IE兼容) 代码如下:function get
Node
Value
(
node
) { if(
node
&&
node
.hasChild
Node
s()){ //return
node
.firstChild.
node
Value
;
最近在写解析XML的程序,可能是更新jar包的原因,原有程序居然报错了,程序代码:
org.w3c.
dom
.
Node
List rsdes = resDoc.get
Element
sByTagName("resultdescription");
if(rsdes!=
null
&&rsdes.getLength()>0){
throw new RuntimeException(rsdes.item(
在学习
DOM
解析XML的内容时,最先学习了读取XML中的内容,但是利用get
Node
Value
()方法时,常常获得
null
;要不然就是报
Null
PointerException空指针错误。于是我就查阅了相关的内容,将这个知识点总结一下。首先贴出我的XML中的内容:
<?xml version="1.0" encoding="UTF-8"?>
<Languages cat="it"...
缺少前提判定:利用条件语句加以判定,不为空的时候再用相应的实体类去接收对象,并给相应控件赋值:
Intent intent=getIntent();
if(intent.getSerializableExtra("item")!=
null
){
JsbMiddle middle= (JsbMiddle) intent.getSerializableExtr
get
Node
Value
是获取当前节点的值;
element
在setTextContent的时候其实是给节点 #text 设置值;所以
element
获取
value
时调用getFirstChild的
value
实际
调用的是第一个#text ,而
element
直接调用get
Node
Value
为空值
文章目录一、树的概念1、特点2、树的术语3、树的种类4、树的存储与表示5、常见的树的应用场景二、二叉树1、概念2、性质
一、树的概念
树是一种抽象数据类型(ADT)或是视作这种抽象数据类型的数据结构
每个节点有零个或多个子节点
没有父节点的节点称为根节点
每一个非根节点有且只有一个父节点
除了根节点外,每个子节点可以分为**多个不相交(因为都只有一个父节点)**的子树
2、树的术语
节点的度:一个节点含有的子树的个数称为该节点的度
树的度:一棵树中,最大的节点的度称为树的度
叶节点或终端节点
Java中可以使用XPath来获取XML文档中节点的值。
首先,需要创建一个`javax.xml.xpath.XPath`对象,然后使用`XPathExpression`来编译XPath表达式,最后使用`XPathExpression.evaluate`方法来执行XPath表达式并获取节点的值。
例如,下面的代码演示了如何使用XPath获取XML文档中的节点值:
```java
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathFactory;
import org.w3c.
dom
.Document;
import org.w3c.
dom
.
Node
List;
// ...
XPathFactory xpathFactory = XPathFactory.newInstance();
XPath xpath = xpathFactory.newXPath();
// 编译XPath表达式
XPathExpression expr = xpath.compile("/root/
node
/text()");
// 执行XPath表达式并获取节点列表
Node
List
node
s = (
Node
List) expr.evaluate(doc, XPathConstants.
NODE
SET);
// 遍历节点列表并输出节点的值
for (int i = 0; i <
node
s.getLength(); i++) {
System.out.println(
node
s.item(i).get
Node
Value
());
其中,`doc`是一个`org.w3c.
dom
.Document`对象,表示XML文档。
注意,需要导入以下依赖才能使用上述代码:
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathFactory;