第四节 使用Jsoup修改数据

亮子 2022-02-21 12:30:57 11009 0 0 0

1、设置属性值

1)存在问题

 在你解析一个Document之后可能想修改其中的某些属性值,然后再保存到磁盘或都输出到前台页面。

2)方法

 可以使用属性设置方法 Element.attr(String key, String value), 和 Elements.attr(String key, String value).

 假如你需要修改一个元素的 class 属性,可以使用 Element.addClass(String className) 和 Element.removeClass(String className) 方法。

 Elements 提供了批量操作元素属性和class的方法,比如:要为div中的每一个a元素都添加一个 rel=“nofollow” 可以使用如下方法:

doc.select("div.comments a").attr("rel", "nofollow");

3)说明

 与Element中的其它方法一样,attr 方法也是返回当 Element (或在使用选择器是返回 Elements 集合)。

 这样能够很方便使用方法连用的书写方式。比如:

doc.select("div.masthead").attr("title", "jsoup").addClass("round-box");

2、设置一个元素的HTML内容

1)存在问题

 你需要一个元素中的HTML的内容

2)方法

 可以使用Element中的HTML设置方法具体如下:

Element div = doc.select("div").first(); // <div></div>
div.html("<p>lorem ipsum</p>"); // <div><p>lorem ipsum</p></div>
div.prepend("<p>First</p>");//在div前添加html内容
div.append("<p>Last</p>");//在div之后添加html内容
// 添完后的结果: <div><p>First</p><p>lorem ipsum</p><p>Last</p></div>

Element span = doc.select("span").first(); // <span>One</span>
span.wrap("<li><a href='http://example.com/'></a></li>");
// 添完后的结果: <li><a href="http://example.com"><span>One</span></a></li>

3)说明

 Element.html(String html) 这个方法将先清除元素中的HTML内容,然后用传入的HTML代替。

 Element.prepend(String first) 和 Element.append(String last) 方法用于在分别在元素内部HTML的前面和后面添加HTML内容

 Element.wrap(String around) 对元素包裹一个外部HTML内容。