Python爬虫实战之爬取京东商品数据并实实现数据可视化


Posted in Python onJune 07, 2021

一、开发工具

Python版本:3.6.4

相关模块:

DecryptLogin模块;

argparse模块;

以及一些python自带的模块。

二、环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。

三、原理简介

原理其实挺简单的,首先,我们利用之前开源的DecryptLogin库来实现一下微博的模拟登录操作:

'''模拟登录京东'''
@staticmethod
def login():
    lg = login.Login()
    infos_return, session = lg.jingdong()
    return session

然后写几行简单的代码来保存一下登录后的会话,省得每次运行程序都要先模拟登录京东:

if os.path.isfile('session.pkl'):
    print('[INFO]: 检测到已有会话文件session.pkl, 将直接导入该文件...')
    self.session = pickle.load(open('session.pkl', 'rb'))
    self.session.headers.update({'Referer': ''})
else:
    self.session = JDGoodsCrawler.login()
    f = open('session.pkl', 'wb')
    pickle.dump(self.session, f)
    f.close()

接着去京东抓一波包,一样的套路,有种屡试不爽的感觉:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

看看请求这个接口需要提交的参数:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

我们可以简单分析一下每个参数的含义:

area: 不用管,可以看作一个固定值
enc: 指定编码, 可以看作固定值"utf-8"
keyword: 搜索的关键词
adType: 不用管,可以看作一个固定值
page: 当前的页码
ad_ids: 不用管,可以看作一个固定值
xtest: 不用管,可以看作一个固定值
_: 时间戳

也就是说我们需要提交的params的内容大概是这样子的:

params = {
            'area': '15',
            'enc': 'utf-8',
            'keyword': goods_name,
            'adType': '7',
            'page': str(page_count),
            'ad_ids': '291:19',
            'xtest': 'new_search',
            '_': str(int(time.time()*1000))
        }

构造好需要提交的params之后,只需要利用登录后的session去请求我们抓包得到的接口:

response = self.session.get(search_url, params=params)

然后从返回的数据里解析并提取我们需要的数据就可以啦:

response_json = response.json()
all_items = response_json.get('291', [])
for item in all_items:
    goods_infos_dict.update({len(goods_infos_dict)+1: 
                                {
                                    'image_url': item.get('image_url', ''),
                                    'price': item.get('pc_price', ''),
                                    'shop_name': item.get('shop_link', {}).get('shop_name', ''),
                                    'num_comments': item.get('comment_num', ''),
                                    'link_url': item.get('link_url', ''),
                                    'color': item.get('color', ''),
                                    'title': item.get('ad_title', ''),
                                    'self_run': item.get('self_run', ''),
                                    'good_rate': item.get('good_rate', '')
                                }
                            })

四、数据可视化

老规矩,可视化一波我们爬取到的数据呗。以我们爬取到的无人机商品数据为例。首先,我们来看看京东里卖无人机的自营店和非自营店比例吧:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

咦,竟然是非自营店占多。我一直以为京东基本都是自营店,虽然我基本不用京东。真是个天大的误解T_T。

接着,我们再来看看京东自己给的商品排名前10的那几家店的商品评论数量呗:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

对比一下评论最多的店铺:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

看来评论数量和京东给的商品排名并没有直接联系T_T,竟然没有一家店是重复的。

再来看看无人机相关商品的价格分布呗:

Python爬虫实战之爬取京东商品数据并实实现数据可视化

到此这篇关于Python爬虫实战之爬取京东商品数据并实实现数据可视化的文章就介绍到这了,更多相关Python可视化京东商品数据 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python中while循环语句用法简单实例
May 07 Python
Python2.x版本中maketrans()方法的使用介绍
May 19 Python
Python利用带权重随机数解决抽奖和游戏爆装备问题
Jun 16 Python
Python控制多进程与多线程并发数总结
Oct 26 Python
详谈python3 numpy-loadtxt的编码问题
Apr 29 Python
Python处理命令行参数模块optpars用法实例分析
May 31 Python
使用python 3实现发送邮件功能
Jun 15 Python
深入浅析Python2.x和3.x版本的主要区别
Nov 30 Python
Python函数参数匹配模型通用规则keyword-only参数详解
Jun 10 Python
PyCharm第一次安装及使用教程
Jan 08 Python
python Cartopy的基础使用详解
Nov 01 Python
python制作一个简单的gui 数据库查询界面
Nov 19 Python
Python实现的扫码工具居然这么好用!
Jun 07 #Python
忆童年!用Python实现愤怒的小鸟游戏
python单元测试之pytest的使用
Jun 07 #Python
Python趣味实战之手把手教你实现举牌小人生成器
怎么用Python识别手势数字
利用python调用摄像头的实例分析
Jun 07 #Python
python通过opencv调用摄像头操作实例分析
Jun 07 #Python
You might like
php获取淘宝分类id示例
2014/01/16 PHP
Codeigniter(CI)框架分页函数及相关知识
2014/11/03 PHP
PHP传参之传值与传址的区别
2015/04/24 PHP
特殊字符、常规符号及其代码对照表
2006/06/26 Javascript
js验证表单第二部分
2006/11/25 Javascript
一个js拖拽的效果类和dom-drag.js浅析
2010/07/17 Javascript
ajax上传时参数提交不更新等相关问题
2012/12/11 Javascript
js图片向右一张张滚动效果实例代码
2013/11/23 Javascript
Ionic实现仿通讯录点击滑动及$ionicscrolldelegate使用分析
2016/01/18 Javascript
AngularJS 中文API参考手册
2016/07/28 Javascript
相册展示PhotoSwipe.js插件实现
2016/08/25 Javascript
让你彻底掌握es6 Promise的八段代码
2017/07/26 Javascript
React Native 使用Fetch发送网络请求的示例代码
2017/12/02 Javascript
vue实现消息的无缝滚动效果的示例代码
2017/12/05 Javascript
利用Node.js检测端口是否被占用的方法
2017/12/07 Javascript
vue-cli常用设置总结
2018/02/24 Javascript
JS解析后台返回的JSON格式数据实例
2018/08/06 Javascript
vue 中引用gojs绘制E-R图的方法示例
2018/08/24 Javascript
vue组件实践之可搜索下拉框功能
2018/11/25 Javascript
vue监听用户输入和点击功能
2019/09/27 Javascript
简单实现节流函数和防抖函数过程解析
2019/10/08 Javascript
vue实现导航标题栏随页面滚动渐隐渐显效果
2020/03/12 Javascript
js实现滑动滑块验证登录
2020/07/24 Javascript
Python操作使用MySQL数据库的实例代码
2017/05/25 Python
解决PyCharm中光标变粗的问题
2017/08/05 Python
python 接口测试response返回数据对比的方法
2018/02/11 Python
Python使用一行代码获取上个月是几月
2018/08/30 Python
Python文件监听工具pyinotify与watchdog实例
2018/10/15 Python
python交互界面的退出方法
2019/02/16 Python
python实现人工智能Ai抠图功能
2019/09/05 Python
python获取全国城市pm2.5、臭氧等空气质量过程解析
2019/10/12 Python
美国演唱会和体育门票购买网站:Ticketnetwork
2018/10/19 全球购物
英国在线购买轮胎、预订汽车、汽车维修和装配网站:Protyre
2020/04/12 全球购物
大学学年自我鉴定
2013/10/28 职场文书
学习保证书怎么写
2015/02/26 职场文书
html+css实现滚动到元素位置显示加载动画效果
2021/08/02 HTML / CSS