没有jsoup,rust怎么解析html呢?

在 Rust 中,你可以使用各种库来解析网页内容。一个常用的库是 reqwest ,它提供了一个简单的方式来发送 HTTP 请求并获取网页内容。另外,你可以使用 scraperselect 等库来解析 HTML 或 XML 格式的网页内容。

下面是一个使用 reqwestscraper 库解析网页内容的示例:

首先,将以下内容添加到你的 Cargo.toml 文件中:

bash 复制代码
[dependencies]
reqwest = "0.11"
scraper = "0.12"

然后,创建一个 Rust 文件,并添加以下代码:

bash 复制代码
use reqwest::blocking::get;
use scraper::{Html, Selector};
 fn main() {
    // 发送 HTTP GET 请求获取网页内容
    let response = get("https://example.com").expect("Failed to send request");
    let body = response.text().expect("Failed to get response body");
     // 使用 scraper 解析 HTML
    let document = Html::parse_document(&body);
    let selector = Selector::parse("h1").expect("Failed to parse selector");
     // 提取特定元素的内容
    let h1_text = document.select(&selector).next().map(|element| element.text().collect::<String>());
     // 打印提取的内容
    if let Some(text) = h1_text {
        println!("H1 Text: {}", text);
    } else {
        println!("No H1 element found");
    }
}

在这个示例中,我们使用 reqwest 库发送 HTTP GET 请求并获取网页内容。然后,我们使用 scraper 库解析 HTML 内容。在这个示例中,我们使用 Selector 来选择 <h1> 元素,并提取其文本内容。

下面我们再看下 Selector 的其他用法,下面是三个使用 scraper 库的 Selector 类的示例,分别用于解析出 <p> 标签、解析出指定 class 的元素以及解析出指定 id 的元素。

  1. 解析出 <p> 标签:
rust 复制代码
use scraper::{Html, Selector};
 fn main() {
    let html = r#"
        <html>
            <body>
                <div>
                    <p>Paragraph 1</p>
                    <p>Paragraph 2</p>
                </div>
            </body>
        </html>
    "#;
     let document = Html::parse_document(html);
    let selector = Selector::parse("p").unwrap();
     for element in document.select(&selector) {
        let text = element.text().collect::<String>();
        println!("Text: {}", text);
    }
}
  1. 解析出指定 class 的元素:
rust 复制代码
use scraper::{Html, Selector};
 fn main() {
    let html = r#"
        <html>
            <body>
                <div>
                    <p class="highlight">Paragraph 1</p>
                    <p>Paragraph 2</p>
                </div>
            </body>
        </html>
    "#;
     let document = Html::parse_document(html);
    let selector = Selector::parse("p.highlight").unwrap();
     for element in document.select(&selector) {
        let text = element.text().collect::<String>();
        println!("Text: {}", text);
    }
}
  1. 解析出指定 id 的元素:
rust 复制代码
use scraper::{Html, Selector};
 fn main() {
    let html = r#"
        <html>
            <body>
                <div>
                    <p id="my-paragraph">Paragraph 1</p>
                    <p>Paragraph 2</p>
                </div>
            </body>
        </html>
    "#;
     let document = Html::parse_document(html);
    let selector = Selector::parse("#my-paragraph").unwrap();
     for element in document.select(&selector) {
        let text = element.text().collect::<String>();
        println!("Text: {}", text);
    }
}
相关推荐
积极向上的龙7 小时前
首屏优化,webpack插件用于给html中js自动添加异步加载属性
javascript·webpack·html
小堃学编程11 小时前
前端学习(1)—— 使用HTML编写一个简单的个人简历展示页面
前端·javascript·html
明月看潮生12 小时前
青少年编程与数学 02-019 Rust 编程基础 08课题、字面量、运算符和表达式
开发语言·青少年编程·rust·编程与数学
天天打码13 小时前
Rspack:字节跳动自研 Web 构建工具-基于 Rust打造高性能前端工具链
开发语言·前端·javascript·rust·开源
航Hang*15 小时前
前端项目2-01:个人简介页面
前端·经验分享·html·css3·html5·webstorm
姜 萌@cnblogs17 小时前
开源我的一款自用AI阅读器,引流Web前端、Rust、Tauri、AI应用开发
rust·web·tauri·svelte
水银嘻嘻17 小时前
Web 自动化之 HTML & JavaScript 详解
前端·自动化·html
良木林19 小时前
HTML难点小记:一些简单标签的使用逻辑和实用化
前端·html
明月看潮生1 天前
青少年编程与数学 02-019 Rust 编程基础 05课题、复合数据类型
开发语言·青少年编程·rust·编程与数学
Uncomfortableskiy1 天前
Rust 官方文档:人话版翻译指南
开发语言·rust