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

作者:weixin_43649691 时间:2023-11-02 18:42:38 

一、开发工具

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爬虫实战之爬取京东商品数据并实实现数据可视化

来源:https://blog.csdn.net/weixin_43649691/article/details/117560643

标签:Python,爬取,数据,可视化
0
投稿

猜你喜欢

  • Golang中的错误处理深入分析

    2024-02-18 20:59:46
  • php统计数组不同元素的个数的实例方法

    2023-06-11 23:04:59
  • JS获得选取checkbox整行数据的方法

    2024-02-26 21:10:33
  • 如何解决django-celery启动后迅速关闭

    2022-02-07 10:50:25
  • 详解Python装饰器

    2023-11-12 12:40:06
  • Go语言测试库testify使用学习

    2024-04-26 17:31:57
  • SQL Server自动更新统计信息的基本算法

    2012-10-07 11:02:50
  • Linux下使用Jenkins自动化构建.NET Core应用

    2024-05-13 09:16:36
  • 浅析Python 抽象工厂模式的优缺点

    2021-08-12 01:33:17
  • 一步步详细讲解vue3配置ESLint

    2024-06-05 15:31:55
  • Python实现学生信息管理系统的示例代码

    2022-12-06 22:17:56
  • Python网络编程使用select实现socket全双工异步通信功能示例

    2023-04-10 21:06:59
  • 深入理解Django的信号机制

    2023-01-20 10:19:58
  • Python多线程编程之多线程加锁操作示例

    2023-11-01 00:37:19
  • WebStorm安装配置教程

    2022-01-17 01:25:24
  • Go语言使用Etcd实现分布式锁

    2024-04-23 09:37:33
  • np.where()[0] 和 np.where()[1]的具体使用

    2023-04-21 20:21:29
  • CentOS7安装mysql5.7解压缩版简明教程

    2024-01-20 14:57:18
  • Python操作MySQL数据库的示例代码

    2024-01-29 03:55:09
  • 探讨:Oracle数据库查看一个进程是如何执行相关的实际SQL语句

    2024-01-16 19:07:50
  • asp之家 网络编程 m.aspxhome.com