最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • python怎样抓取js生成的页面

    正文概述    2020-05-18   149

    之前我们爬取的网页,多是HTML静态生成的内容,直接从HTML源码中就能找到看到的数据和内容,然而并不是所有的网页都是这样的。

    python怎样抓取js生成的页面

    有一些网站的内容由前端的JS动态生成,由于呈现在网页上的内容是由JS生成而来,我们能够在浏览器上看得到,但是在HTML源码中却发现不了。比如今日头条:

    浏览器呈现的网页是这样的:

    python怎样抓取js生成的页面

    查看源码,却是这样的:

    python怎样抓取js生成的页面

    网页的新闻在HTML源码中一条都找不到,全是由JS动态生成加载。

    遇到这种情况,我们应该如何对网页进行爬取呢?有两种方法:

    1、从网页响应中找到JS脚本返回的JSON数据;2、使用Selenium对网页进行模拟访问

    一、从网页响应中找到JS脚本返回的JSON数据

    即使网页内容是由JS动态生成加载的,JS也需要对某个接口进行调用,并根据接口返回的JSON数据再进行加载和渲染。

    所以我们可以找到JS调用的数据接口,从数据接口中找到网页中最后呈现的数据。

    就以今日头条为例来演示:

    1、从找到JS请求的数据接口

    F12打开网页调试工具

    python怎样抓取js生成的页面

    选择“网络”选项卡后,发现有很多响应,我们筛选一下,只看XHR响应。

    (XHR是Ajax中的概念,表示XMLHTTPrequest)

    然后我们发现少了很多链接,随便点开一个看看:

    我们选择city,预览中有一串json数据:

    python怎样抓取js生成的页面

    我们再点开看看:

    python怎样抓取js生成的页面

    原来全都是城市的列表,应该是加载地区新闻之用的。

    现在大概了解了怎么找JS请求的接口的吧?但是刚刚我们并没有发现想要的新闻,再找找看:

    有一个focus,我们点开看看:

    python怎样抓取js生成的页面

    与首页的图片新闻呈现的数据是一样的,那么数据应该就在这里面了。

    看看其他的链接:

    python怎样抓取js生成的页面

    这应该是热搜关键词

    python怎样抓取js生成的页面

    这个就是图片新闻下面的新闻了。

    我们打开一个接口链接看看:http://www.toutiao.com/api/pc/focus/

    python怎样抓取js生成的页面

    返回一串乱码,但从响应中查看的是正常的编码数据:

    python怎样抓取js生成的页面

    有了对应的数据接口,我们就可以仿照之前的方法对数据接口进行请求和获取响应了

    2、请求和解析数据接口数据

    先上完整代码:

    # coding:utf-8
    import requests
    import json
    
    url = 'http://www.toutiao.com/api/pc/focus/'
    wbdata = requests.get(url).text
    
    data = 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)

    返回出来的结果如下:

    python怎样抓取js生成的页面

    代码分为四部分

    第一部分:引入相关的库

    # coding:utf-8
    import requests
    import json

    第二部分:对数据接口进行http请求

    url = 'http://www.toutiao.com/api/pc/focus/'
    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生成的页面

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元