一个是字符一个是文件流
对啊 是属性名
JDK版本的问题 把JDK降到1.8以下就没有了
和我的问题完全一样啊,解决了吗
怎么了??
JDK版本问题,换成视频中的jdk7或者jdk8就可以了
SAXBuilder builder = new SAXBuilder(false);
t doc = builder.build(in);
从上面代码中可以看出,JDOM使用SAX2 解析器来解析和验证输入 XML 文档,然后构建Doucment对象。
DOM4J是JDOM的一种智能分支,它合并了许多超出基本XML文档表示的功能。
所以dom4j和jdom采用的解析方式都是SAX
就是子节点的子节点啊
导入 先大致浏览下 是可以的
首先,代码是从百度贴的,简单说下,这里如果要解析注释的话,就不能用迭代器Iterator来迭代element了,从代码可以看出,element只是node的接口之一,而注释节点的继承结构里没有element接口,需要使用如下的遍历方式才能得到,原理大概是这样,如有不明白的地方,欢迎追问
Element root= doc.getRootElement();
for (int i = 0, size = root.nodeCount(); i < size; i++)
{
Node node = root.node(i);
if (node instanceof Element) {
System.out.println("This is a Element!");
prinContent(node);
System.out.println();
} else if(node instanceof
org.dom4j.Comment){
System.out.println("This is a Comment!");
prinContent(node);
System.out.println();
}else{
System.out.println("This is a Nothing!");
prinContent(node);
}
}
http://jaist.dl.sourceforge.net/project/dom4j/dom4j/1.6.1/dom4j-1.6.1.zip 去下载
Iterator<E>的问题
....
一般这种情况,有加类型的是没加类型的细化,比如 getStringValue得到的就是String的返回值了,而getValue则是Object型的,如果是字符串型的,你还得自己再转成String