Python中怎么获取JS动态内容 DATE: 2023-10-04 05:00:03
这篇文章给大家介绍Python中怎么获取JS动态内容,中获内容非常详细,态内感兴趣的中获小伙伴们可以参考借鉴,希望对大家能有所帮助。态内
网页的中获新闻在HTML源码中一条都找不到,全是态内由JS动态生成加载。
遇到这种情况,中获我们应该如何对网页进行爬取呢?有两种方法:
1、态内从网页响应中找到JS脚本返回的中获JSON数据;2、使用Selenium对网页进行模拟访问
在此只对第一种方法作介绍,态内关于Selenium的中获使用,后面有专门的态内一篇。
从网页响应中找到JS脚本返回的中获JSON数据
即使网页内容是由JS动态生成加载的,JS也需要对某个接口进行调用,态内并根据接口返回的中获JSON数据再进行加载和渲染。
所以我们可以找到JS调用的数据接口,从数据接口中找到网页中最后呈现的数据。
就以今日头条为例来演示:
1、从找到JS请求的数据接口
undefined
undefined
undefined
undefined
undefined
undefined
undefined
undefined
undefined
与首页的图片新闻呈现的数据是一样的,那么数据应该就在这里面了。
看看其他的链接:
这应该是热搜关键词
这个就是图片新闻下面的新闻了。
我们打开一个接口链接看看:http://www.toutiao.com/api/pc/focus/
返回一串乱码,但从响应中查看的是正常的编码数据:
有了对应的数据接口,我们就可以仿照之前的方法对数据接口进行请求和获取响应了
2、请求和解析数据接口数据
先上完整代码:
# coding:utf-8import requestsimport jsonurl = 'http://www.toutiao.com/api/pc/focus/'wbdata = requests.get(url).textdata = json.loads(wbdata)news = data['data']['pc_feed_focus']for n in news: title = n['title'] img_url = n['image_url'] url = n['media_url'] print(url,title,img_url)
返回出来的结果如下:
照例,稍微讲解一下代码:
代码分为四部分,
第一部分:引入相关的库
# coding:utf-8import requestsimport json
第二部分:对数据接口进行http请求
url = ' wbdata = requests.get(url).text
第三部分:对HTTP响应的数据JSON化,并索引到新闻数据的位置
data = json.loads(wbdata)news = data['data']['pc_feed_focus']
第四部分:对索引出来的JSON数据进行遍历和提取
for n in news: title = n['title'] img_url = n['image_url'] url = n['media_url'] print(url,title,img_url)
关于Python中怎么获取JS动态内容就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。