Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

昨天有小伙伴找我,新浪新闻的国内新闻页,其他部分都是静态网页可以抓到,但是在左下方的最新新闻部分,不是静态网页,也没有json数据,让我帮忙抓一下。大概看了下,是js加载的,而且数据在js函数中,很有意思,就分享出来给大家一起看看!

抓取目标

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

今天我们的目标是上图红框部分,首先我们确定这部分内容不在网页源代码中,属于js加载的部分,点击翻页后也没有json数据传输!

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

但是发现有个js的请求,点击请求,是一行js函数代码,我们将其复制到json的视图查看器中,然后格式化一下,看看结果

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程
Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

发现里面有可能存在我们需要的内容,比如url、title、intro这3个参数,猜测就是对应的新闻URL、标题、简介

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

只是其内容,需要在进行处理一下,我们写到代码中看看

开始写代码

先导入库,因为最终需要从字符串中截取部分,所以用requests库获取请求,正则re匹配内容即可。然后我们先匹配出上述3项

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

可以看到,url中存在 \ \,标题和简介是以\ \ u4e09的形式存在,这些就是我们需要处理的下一步了!

先用replace函数剔除url中\ \,即可得到url,后面的\ \ u4e09则是unicode编码,可以直接解码得到内容,直接写代码了

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

解码用了eval函数,内容为u“ + unicode编码内容 + “的形式即可解码!

这样,就取出了本页的所有新闻和URL的相关内容,在外层加上循环,即可抓取所有的新闻页,任务完成!

Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程

后记

新浪新闻的页面js函数比较简单,可以直接抓到数据,如果是比较复杂的函数的话,就需要深入理解前端知识了,这也是为什么学爬虫,需要学习前端知识的原因!

ps:上文所用的json查看器是第三方的网站,直接百度即可找到很多,当然也可以直接将上述抓包的内容修改,然后用json读取数据也是可以的!

基本代码没有多少,如果有看不清楚的小伙伴,可以私信我获取代码或者一起研究爬虫哦!

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,087评论 3 119
  • 一道玻璃割裂天际 透明、清晰 望着那头 世界没有什么不同 伸出的手 却被阻绝 只能呼喊 大声呼喊 那边的人笑笑 望...
    叶浟阅读 1,459评论 2 3
  • 此刻,我在图书馆里坐着,拿着手机准备写下今天自己规定的任务。周围静的可以让我听见每一个人的心跳,这样的氛围,让我不...
    一杯热咖啡阅读 4,581评论 3 2
  • 09125 杨燕燕 今天Emily要跟大家分享一本非常适合睡前亲子阅读的绘本,那就是Margaret Wise B...
    Emilyyyy阅读 2,271评论 0 0
  • 请不要误会 我其实是个很俗的人 吃饭的时候 我会很大声的叭唧嘴 睡觉的时候 我会咬牙 打呼噜 还经常放屁 走路的时...
    李萌帅阅读 3,938评论 0 1

友情链接更多精彩内容