如何用Jsoup库提取商品名称和价格?

使用 Jsoup 库提取商品名称和价格是一个常见的任务,尤其是在爬取电商网站的商品详情时。Jsoup 是一个非常强大的 HTML 解析库,可以方便地从 HTML 文档中提取数据。以下是如何使用 Jsoup 提取商品名称和价格的详细步骤和代码示例。

一、环境准备

确保你的项目中已经添加了 Jsoup 依赖。如果你使用的是 Maven,可以在 pom.xml 文件中添加以下依赖:

xml

XML 复制代码
<dependency>
    <groupId>org.jsoup</groupId>
    <artifactId>jsoup</artifactId>
    <version>1.13.1</version>
</dependency>

二、代码实现

(一)发送 HTTP 请求

使用 Jsoup 发送 GET 请求,获取商品详情页面的 HTML 内容。

java

java 复制代码
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;

import java.io.IOException;

public class JDProductCrawler {

    public static Document getHtml(String url) throws IOException {
        return Jsoup.connect(url)
                .userAgent("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3")
                .get();
    }
}
(二)解析 HTML 内容

使用 Jsoup 解析 HTML 内容,提取商品名称和价格。

java

java 复制代码
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;

import java.util.HashMap;
import java.util.Map;

public class JDProductParser {

    public static Map<String, String> parseHtml(Document doc) {
        Map<String, String> productDetails = new HashMap<>();

        // 提取商品名称
        Elements titleElements = doc.select("div.sku-name");
        if (!titleElements.isEmpty()) {
            productDetails.put("name", titleElements.first().text().trim());
        }

        // 提取商品价格
        Elements priceElements = doc.select("span.price.J-p-123456");
        if (!priceElements.isEmpty()) {
            productDetails.put("price", priceElements.first().text().trim());
        }

        return productDetails;
    }
}
(三)整合代码

将上述功能整合到主程序中,实现完整的爬虫程序。

java

java 复制代码
import java.util.Map;

public class Main {

    public static void main(String[] args) {
        String productUrl = "https://item.jd.com/123456.html"; // 替换为实际商品页面 URL
        try {
            Document doc = JDProductCrawler.getHtml(productUrl);
            Map<String, String> productDetails = JDProductParser.parseHtml(doc);

            System.out.println("商品名称: " + productDetails.get("name"));
            System.out.println("商品价格: " + productDetails.get("price"));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

三、注意事项

  1. 页面结构变化 :电商网站的页面结构可能会发生变化,因此需要定期检查和更新选择器(select 方法中的参数)。

  2. 异常处理:在发送请求和解析 HTML 时,可能会遇到各种异常情况,如请求失败、页面结构变化等。因此,需要在代码中添加异常处理逻辑,确保爬虫的稳定运行。

  3. 遵守法律法规 :在进行爬虫操作时,必须严格遵守相关法律法规,尊重网站的 robots.txt 文件规定。

  4. 合理设置请求频率:避免过高的请求频率导致对方服务器压力过大,甚至被封禁 IP。建议每次请求之间至少间隔 1-2 秒。

四、总结

通过上述步骤和代码示例,你可以轻松地使用 Jsoup 提取京东商品的名称和价格。Jsoup 提供了非常强大的 HTML 解析功能,可以方便地从复杂的 HTML 文档中提取所需的数据。希望这个指南对你有所帮助!如果你对爬虫开发有更多兴趣,可以尝试探索更复杂的功能,如多线程爬取、数据可视化等。

相关推荐
开开心心就好5 分钟前
高效全能PDF工具,支持OCR识别
java·前端·python·pdf·ocr·maven·jetty
冷心笑看丽美人6 分钟前
Spring MVC数据绑定和响应 你了解多少?
java·spring·mvc
XQ丶YTY13 分钟前
大二java第一面小厂(挂)
java·开发语言·笔记·学习·面试
一零贰肆29 分钟前
深入理解SpringBoot中的SpringCache缓存技术
java·springboot·springcache·缓存技术
码上飞扬1 小时前
Java大师成长计划之第22天:Spring Cloud微服务架构
java·运维·云计算
秋野酱1 小时前
基于javaweb的SpringBoot自习室预约系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
whoarethenext2 小时前
c/c++爬虫总结
c语言·c++·爬虫
面试官E先生2 小时前
【极兔快递Java社招】一面复盘|数据库+线程池+AQS+中间件面面俱到
java·面试
琢磨先生David2 小时前
构建优雅对象的艺术:Java 建造者模式的架构解析与工程实践
java·设计模式·建造者模式
小雅痞2 小时前
[Java][Leetcode simple]26. 删除有序数组中的重复项
java·leetcode