网站首页 > java教程 正文
1.Jsoup介绍
- 官网文档:https://jsoup.org
- Jsoup 是一款Java 的HTML解析器,可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQuery的操作方法来取出和操作数据。
2. Jsoup快速入门
- 获取网页标题
String url = "https://search.jd.com/Search?keyword=手机&wq=手机&page=1";
Document document = Jsoup.connect(url).get();
String title = document.select("title").text();
System.out.println(title);
```
- 运行效果:手机 - 商品搜索 - 京东
3. 网站数据分析
3.1 分析网站的访问地址
- 以京东商城为例,商品分页列表的url地址,需要带如下几个参数,因此,在发送http请求时,需要携带正确的参数。
- URL:https://search.jd.com/Search?keyword=手机&wq=手机&page=1
3.2 分析网站的页面结构
- 通过浏览器的开发者工具,可以分析出页面中我们需要的html结构。
<img src="assets/image-20220717171103097.png" alt="image-20220717171103097" style="zoom:67%;" />
- 可以看出,我们需要的商品数据,封装在一个id=J_goodsList的div标签中,我们可以方便的通过DOM解析出这块数据。
4. 实战实现过程
- 获取第1页的商品基本数据
public static void main(String[] args) throws Exception {
//第1页地址
String url = "https://search.jd.com/Search?keyword=手机&wq=手机&page=1";
//发送http请求
Document document = Jsoup.connect(url).get();
//在id=J_goodsList的div下,获取所有带有data-sku属性的li标签
Elements lis = document.select("div[id=J_goodsList] li[data-sku]");
lis.forEach(
li -> {
//获取商品sku
String sku = li.attr("data-sku");
//获取商品name
String name = li.select("div[class='p-name p-name-type-2'] a em").text();
//获取商品图片地址
String img = li.select("div[class=p-img] a img[data-lazy-img]").attr("data-lazy-img");
System.out.println(String.format("%s, %s, %s", sku, name, img));
}
);
}
- 效果预览
- 改造为分页获取
public static void main(String[] args) throws Exception {
//第N页地址
String url = "https://search.jd.com/Search?keyword=手机&wq=手机&page=" + i;
//发送http请求
Document document = Jsoup.connect(url).get();
//在id=J_goodsList的div下,获取所有带有data-sku属性的li标签
Elements lis = document.select("div[id=J_goodsList] li[data-sku]");
lis.forEach(
li -> {
//获取商品sku
String sku = li.attr("data-sku");
//获取商品name
String name = li.select("div[class='p-name p-name-type-2'] a em").text();
//获取商品图片地址
String img = li.select("div[class=p-img] a img[data-lazy-img]").attr("data-lazy-img");
System.out.println(String.format("%s, %s, %s", sku, name, img));
}
);
}
- 上一篇: Java最大的优势真的在于跨平台吗?
- 下一篇: Java Web项目发布,服务器部署(完整版)
猜你喜欢
- 2024-12-31 Java Web项目发布,服务器部署(完整版)
- 2024-12-31 Java最大的优势真的在于跨平台吗?
- 2024-12-31 简洁美观的开源java博客系统
你 发表评论:
欢迎- 最近发表
-
- class版本不兼容错误原因分析(class更新)
- 甲骨文Oracle公司为Java的最新LTS版本做出改进
- 「版本发布」Minecraft Java开发版 1.19.4-pre1 发布
- java svn版本管理工具(svn软件版本管理)
- 我的世界1.8.10钻石在第几层(我的世界1.7.2钻石在哪层)
- Java开发高手必备:在电脑上轻松切换多个JDK版本
- 2022 年 Java 开发报告:Java 8 八年不到,开发者都在用什么?
- 开发java项目,选择哪个版本的JDK比较合适?
- Java版本选型终极指南:8 vs 17 vs 21特性对决!大龄程序员踩坑总结
- POI Excel导入(poi excel导入附件)
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)