Jsoup解析器的使用
<students >
<student number="heima_0001">
<name id="1">
<xing>wu</xing>
<ming>di</ming>
</name>
<age name="xiaoer">19</age>
<sex>male</sex>
</student>
<student number="heima_0002">
<name>wudi</name>
<age>19</age>
<sex>male</sex>
</student>
</students>
package cn.itcast.xml.jsoup;
import java.io.File;
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
/*
* Jsoup快速入门
*/
public class JsoupDemo4 {
public static void main(String[] args) throws IOException {
//2.获取Document对象(是要基于xml文档才可以获取的)
//根据xml文档来获取
//2.1获取student.xml的path
String path=JsoupDemo4.class.getClassLoader().getResource("student.xml").getPath();
//2.2解析xml文档,加载文档进内存,获取dom树(也就获取到了document对象)
Document document = Jsoup.parse(new File(path),"utf-8");//字符集和文本的字符集一致
//3.获取元素对象
//返回的是elements(element的集合)
//Document获取到的是所有的name标签
// Elements elements = document.getElementsByTag("name"); //我们获取一下年龄
// System.out.println(elements.size());
// System.out.println("--------------------");
//通过Element对象来获取子标签对象
Element element_student = document.getElementsByTag("student").get(0);
Elements ele_name = element_student.getElementsByTag("name");
// System.out.println(ele_name.size());
//获取student对象的属性值 传一个属性名我们就可以获得属性值
String number = element_student.attr("number");//这里写的属性名是不区分大小写的
// System.out.println(number);
//获取文本内容
String text = ele_name.text();//获取的是所有子标签的纯文本内容
String html = ele_name.html();//把标签名称也获取了
System.out.println(text);
System.out.println("------------");
System.out.println(html);
}
}