0

0

java爬虫jsoup解析HTML实例分析

WBOY

WBOY

发布时间:2023-04-25 13:19:06

|

1744人浏览过

|

来源于亿速云

转载

    前言

    使用python写爬虫的人,应该都听过beautifulsoup4这个包,用来它来解析网页甚是方便。那么在java里有没有类似的包呢?当然有啦!而且也非常好用。下面隆重介绍jsoup

    jsoup 实现了 WHATWG HTML5 规范,能够与现代浏览器解析成相同的DOM。其解析器能够尽最大可能从你提供的HTML文档来创建一个干净的解析结果,无论HTML的格式是否完整。比如它可以处理没有关闭的标签。

    举个栗子:

    <p>Lorem <p>Ipsum parses to <p>Lorem</p> <p>Ipsum</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/c1c2c2ed740f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Java免费学习笔记(深入)</a></a>”;</p>

    它也可以处理隐式标签,创建可靠的文档结构(html标签包含head 和 body,在head只出现恰当的元素)。

    下载

    一个文档的对象模型

    • 文档由多个ElementsTextNodes组成 ;

    • 其继承结构如下:Document继承Element继承NodeTextNode继承 Node.

    • 一个Element包含一个子节点集合,并拥有一个父Element。他们还提供了一个唯一的子元素过滤列表。

    获取 Document 对象

    jsoup 可以从包括字符串、URL 地址以及本地文件来加载 HTML 文档,并生成 Document 对象实例。

    // (1)从字符串中获取
    String html = "<html><head><title>First parse</title></head>"
      + "<body><p>Parsed HTML into a doc.</p></body></html>";
    Document doc1 = Jsoup.parse(html);
    // (2)从 URL 直接加载 HTML 文档
    // get方法
    Document doc2 = Jsoup.connect("http://www.163.com").get(); 
    // post方法
    Document doc = Jsoup.connect("http://example.com")
      .data("query", "Java")
      .userAgent("Mozilla")
      .cookie("auth", "token")
      .timeout(3000)
      .post();
      // (3)从文件中加载 HTML 文档
    File input = new File("D:/test.html"); 
    Document doc = Jsoup.parse(input,"UTF-8","http://www.163.com/");

    常用到的方法如下:

    public static Connection connect(String url)
    public static Document parse(String html, String baseUri)
    public static Document parse(URL url,  int timeoutMillis) throws IOException
    public static Document parse(File in,  String charsetName) throws IOException
    public static Document parse(InputStream in, String charsetName,  String baseUrl)  throws IOException

    parse方法能够将输入的 HTML 解析为一个新的文档 (Document),只要解析的不是空字符串,就能返回一个结构合理的文档,其中包含(至少) 一个head和一个body元素。
    上面的参数 baseUri的作用是,如果要解析的html中存在相对路径,那么就根据这个参数变成绝对路径, 如果不需要可以传入一个空字符串。

    注:通过connect方法来获得 html 源码,有的时候会遇到乱码的问题,这个时候该怎么办么?方法里有一个 parse 方法,传入参数 InputStreamcharsetName以及baseUrl,所有可以这样解决:

    String url = "http://xxxxxxx";
    Document document = Jsoup.parse(new URL(url).openStream(), "GBK", url);// 以 gbk 编码为栗。

    Jsoup的强项是解析html,当然了,它能处理一些简单情况,遇到复杂的情形还是使用 httpClient 这个包吧,你值得拥有!

    解析并提取 HTML 元素

    使用传统的操作DOM的方式

    举个栗子

    Element content = doc.getElementById("content");
    Elements links = content.getElementsByTag("a");
    Elements mx = content.getElementsByClass("help");

    :doc 为 Document 对象。

    还有写常用的方法,比如

    public Elements getElementsByAttributeValue(String key,  String value)
    public Element attr(String attributeKey,  String attributeValue)
    public Elements getAllElements()
    // 获得孩子节点中所有的文本拼接
    public String text()
    // 获得节点的内部html
    public String html()

    Document 对象还有一个方法

    // 获取标题
    public String title()
    // 获得某节点的html,这个方法继承自Node类,所以Element类也有该方法
    public String outerHtml()

    选择器

    在元素检索方面,jsoup 的选择器简直无所不能。

    jsoup 选择器很多,这里仅仅举出几个栗子,

    Elements links = doc.select("a[href]"); // 具有href属性的a标签
    Elements pngs = doc.select("img[src$=.png]");// src属性以.png结尾的img标签
    Element masthead = doc.select("div.masthead").first();// class属性为masthead的div标签中的第一个
    Elements resultLinks = doc.select("h4.r > a"); // class属性为r的h4标签的直接子a标签
    Elements resultLinks = doc.select(img[src~=(?i)\.(png|jpe?g)])

    Selector选择器概述

    tagname: 通过标签查找元素,比如:ans|tag: 通过标签在命名空间查找元素,比如:可以用 fb|name 语法来查找 元素#id: 通过ID查找元素,比如:#logo.class: 通过class名称查找元素,比如:.masthead[attribute]: 利用属性查找元素,比如:[href][^attr]: 利用属性名前缀来查找元素,比如:可以用[^data-] 来查找带有HTML5 Dataset属性的元素[attr=value]: 利用属性值来查找元素,比如:[width=500][attr^=value], [attr$=value], [attr*=value]: 利用匹配属性值开头、结尾或包含属性值来查找元素,比如:[href*=/path/][attr~=regex]: 利用属性值匹配正则表达式来查找元素,比如: img[src~=(?i)\.(png|jpe?g)]*: 这个符号将匹配所有元素

    Selector选择器组合使用

    纳米漫剧流水线
    纳米漫剧流水线

    360推出的国内首个工业级AI漫剧生产平台

    下载

    el#id: 元素+ID,比如: div#logo

    el.class: 元素+class,比如: div.masthead

    el[attr]: 元素+class,比如: a[href]

    任意组合,比如:a[href].highlight

    ancestor child: 查找某个元素下子元素,比如:可以用.body p 查找在"body"元素下的所有 p元素

    parent > child: 查找某个父元素下的直接子元素,比如:可以用div.content > p 查找 p 元素,也可以用body > * 查找body标签下所有直接子元素

    siblingA + siblingB: 查找在A元素之前第一个同级元素B,比如:div.head + div

    siblingA ~ siblingX: 查找A元素之前的同级X元素,比如:h2 ~ p

    el, el, el:多个选择器组合,查找匹配任一选择器的唯一元素,例如:div.masthead, div.logo

    伪选择器selectors

    :lt(n): 查找哪些元素的同级索引值(它的位置在DOM树中是相对于它的父节点)小于n,比如:td:lt(3) 表示小于三列的元素

    :gt(n):查找哪些元素的同级索引值大于n,比如: div p:gt(2)表示哪些div中有包含2个以上的p元素

    :eq(n): 查找哪些元素的同级索引值与n相等,比如:form input:eq(1)表示包含一个input标签的Form元素

    :has(seletor): 查找匹配选择器包含元素的元素,比如:div:has(p)表示哪些div包含了p元素

    :not(selector): 查找与选择器不匹配的元素,比如: div:not(.logo) 表示不包含 class=logo 元素的所有 div 列表

    :contains(text): 查找包含给定文本的元素,搜索不区分大不写,比如: p:contains(jsoup)

    :containsOwn(text): 查找直接包含给定文本的元素

    :matches(regex): 查找哪些元素的文本匹配指定的正则表达式,比如:div:matches((?i)login)

    :matchesOwn(regex): 查找自身包含文本匹配指定正则表达式的元素

    注: 上述伪选择器索引是从0开始的,也就是说第一个元素索引值为0,第二个元素index为1等。

    对于 Elements 的来历,看这里

    public class Elements extends ArrayList<Element>

    另外,可以查看Selector API参考来了解更详细的内容,可以看出,jsoup 使用跟 jQuery 一模一样的选择器对元素进行检索,以上的检索方法如果换成是其他的 HTML 解释器,至少都需要很多行代码,而 jsoup 只需要一行代码即可完成。

    修改获取数据

    // 为所有链接增加 rel=nofollow 属性
    doc.select("div.comments a").attr("rel", "nofollow"); 
     // 为所有链接增加 class=mylinkclass 属性
    doc.select("div.comments a").addClass("mylinkclass"); 
    // 删除所有图片的 onclick 属性
    doc.select("img").removeAttr("onclick"); 
    // 清空所有文本输入框中的文本
    doc.select("input[type=text]").val(""); 
    // 获得rel属性的值
    doc.select("div.comments a").attr("rel");

    相关文章

    java速学教程(入门到精通)
    java速学教程(入门到精通)

    java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    相关标签:

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    C# ASP.NET Core微服务架构与API网关实践
    C# ASP.NET Core微服务架构与API网关实践

    本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

    16

    2026.03.11

    Go高并发任务调度与Goroutine池化实践
    Go高并发任务调度与Goroutine池化实践

    本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

    23

    2026.03.10

    Kotlin Android模块化架构与组件化开发实践
    Kotlin Android模块化架构与组件化开发实践

    本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

    75

    2026.03.09

    JavaScript浏览器渲染机制与前端性能优化实践
    JavaScript浏览器渲染机制与前端性能优化实践

    本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

    95

    2026.03.06

    Rust内存安全机制与所有权模型深度实践
    Rust内存安全机制与所有权模型深度实践

    本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

    218

    2026.03.05

    PHP高性能API设计与Laravel服务架构实践
    PHP高性能API设计与Laravel服务架构实践

    本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

    420

    2026.03.04

    AI安装教程大全
    AI安装教程大全

    2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

    168

    2026.03.04

    Swift iOS架构设计与MVVM模式实战
    Swift iOS架构设计与MVVM模式实战

    本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

    222

    2026.03.03

    C++高性能网络编程与Reactor模型实践
    C++高性能网络编程与Reactor模型实践

    本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

    33

    2026.03.03

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3.6万人学习

    AngularJS教程
    AngularJS教程

    共24课时 | 4.1万人学习

    CSS教程
    CSS教程

    共754课时 | 41.9万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号