博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python分布式抓取和分析京东商城评价
阅读量:6504 次
发布时间:2019-06-24

本文共 1972 字,大约阅读时间需要 6 分钟。

互联网购物现在已经是非常普遍的购物方式,在互联网上购买商品并且使用之后,很多人都会回过头来对自己购买的商品进行一些评价,以此来表达自己对于该商品使用后的看法。商品评价的好坏对于一个商品的重要性显而易见,大部分消费者都以此作为快速评判该商品质量优劣的方式。所以,与此同时,有些商家为了获得好评,还会做一些 "好评优惠" 或者 "返点" 活动来刺激消费者评价商品。

既然商品评价对于消费者选购商品而言至关重要,那么我想试试可以从这些评价信息中获取到怎样的价值,来帮助消费者快速获取到关于该商品的一些重要信息,给他们的购物带来更加可靠地保证?

所以,我认为,一种快速、全面、高提炼度和高对比度的信息获取和展示方式将会非常必要。 于是,我采用分布式快速抓取京东的评价信息,然后使用 pandas 对抓取到的数据进行分析。

话不多说先附上使用地址

体验地址:http://awolfly9.com/jd/

想要分析京东商城的商品评价信息,那么需要做些什么呢

8481c8f592b7f349aa84a1de5c171db681516edf采用分布式抓取,尽量在短时间内抓取需要分析的商品足够多的评价信息 
8481c8f592b7f349aa84a1de5c171db681516edf
将抓取到的评价信息都存储到数据库
8481c8f592b7f349aa84a1de5c171db681516edf
从数据库中取出所有数据进行数据分析
    • 生成好评的词云,并且获取关键字

    • 生成中评的词云,并且获取关键字

    • 生成差评的词云,并且获取关键字

    • 分析购买该商品不同颜色的比例,生成柱状图

    • 分析购买该商品不同配置的比例,生成柱状图

    • 分析该商品的销售数量和评论数量和时间的关系,生成时间则线图

    • 分析该商品不同省份购买的的比例,生成柱状图

    • 分析该商品不同渠道的销售比例,生成柱状图

8481c8f592b7f349aa84a1de5c171db681516edf
利用 Django 搭建后台,将数据抓取和数据分析连起来
8481c8f592b7f349aa84a1de5c171db681516edf
前端显示数据抓取和分析结果

分布式抓取京东商城的评价信息

采用分布式抓取的目的是快速的在短时间内尽量抓取足够多的商品评价,使分析结果更精确

8481c8f592b7f349aa84a1de5c171db681516edf
为例,通过 Chrome 抓包分析出京东商城的评价请求 URl
8481c8f592b7f349aa84a1de5c171db681516edf找出评价请求 URL 规律,获取到如下 URL 组合链接
8481c8f592b7f349aa84a1de5c171db681516edf利用 Chrome 插件 Postman 测试链接是否可用,发现京东获取评价信息并没有验证 Cookie 之类的反爬措施
8481c8f592b7f349aa84a1de5c171db681516edf开始编码利用 scrapy 抓取京东商城的商品评价信息并存入数据库以备使用

数据分析

8481c8f592b7f349aa84a1de5c171db681516edf从数据库中取出相应数据,开始分析
8481c8f592b7f349aa84a1de5c171db681516edf使用 python 的扩展库 wordcloud 分别提取好评、中评、差评的关键字,并且生成相应的词云图片
8481c8f592b7f349aa84a1de5c171db681516edf分析该商品不同颜色的销量占比,并且生成柱状图,例如 iphone7 的不同颜色金色、玫瑰金色、银色、黑色、亮黑色、还有最新出的红色的占比
8481c8f592b7f349aa84a1de5c171db681516edf分析该商品不同配置的销量占比,并且生成柱状图,例如 iphone7 32G 、 64G、128G 存储
8481c8f592b7f349aa84a1de5c171db681516edf分析该商品销售和评论时间并且生成折线图,分析出商品在什么时间最畅销
8481c8f592b7f349aa84a1de5c171db681516edf分析用户购买该商品的渠道,例如用户通过京东 Android 客户端、微信京东购物、京东 iPhone 客户端购物的比例,并且生成柱状图
8481c8f592b7f349aa84a1de5c171db681516edf分析购买该商品的用户的地域省份。例如北京、上海、广州那个城市在京东上购买 iPhone7 的人更多
8481c8f592b7f349aa84a1de5c171db681516edf将以上分析结果都存储保留

Django 后台 WEB

使用 Django 搭建一个简易的后台 jd_analysis,将分布式抓取数据和数据分析连起来,并且将分析结果返回前端显示。

8481c8f592b7f349aa84a1de5c171db681516edf
jd_analysis 提供一个接口接受用户请求分析的京东商城商品的 URL 链接
8481c8f592b7f349aa84a1de5c171db681516edf
jd_analysis 接受到商品链接后开启爬虫进程开始抓取需要分析的商品的名称和评价数量
组合出完整的评价链接插入到 redis 中,实现分布式爬虫抓取,尽可能在短时间内抓取足够多的该商品评价信息(我现在是 30s 时间大概可以抓取 3000 条评价信息)
8481c8f592b7f349aa84a1de5c171db681516edf
主服务器等待一定的抓取时间,例如主服务器等待 30s,30s 后一定要给前端返回分析结果,所以等 30s 后清空 redis 中该商品的链接,从服务器没有读取不到需要抓取的链接也就自动关闭
8481c8f592b7f349aa84a1de5c171db681516edf
开启分析进程,开始分析抓取到的所有数据,并且生成图标等信息

前端展示

在客户端第一次请求时,生成一个 GUID,并且存储在 cookie 中。然后开启一个定时器,带上 GUID 不断的向 jd_analysis 后台请求结果。jd_analysis 后台利用请求的 GUID 从 redis 中获取抓取信息和分析结果的所有内容,返回给前端。前端显示请求到的结果。

最后附上两张效果图

购买和评论时间折线图

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

购买渠道柱状图
640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=

大功告成

以上就是完整的抓取京东商品的评价信息并且使用 pandas 分析评价然后利用 Django 搭建后台前端显示抓取和分析结果的所有步骤。

原文发布时间为:2017-04-19

本文作者:awolfly9

本文来自云栖社区合作伙伴“”,了解相关信息可以关注“”微信公众号

转载地址:http://rxqyo.baihongyu.com/

你可能感兴趣的文章
java面向对象的概念_java面向对象(上)-- 面向对象的概念
查看>>
java内部类访问外部类变量 final_Java内部类引用外部类中的局部变量为什么必须是final问题解析...
查看>>
java 栈帧与类的关系_深入理解Java虚拟机之类运行时栈帧结构
查看>>
php中删除评论怎么做的,详解PHP如何实现评论回复删除功能
查看>>
macports 安装php,「macports」MacOS 中 MacPorts 安装和使用 - 金橙教程网
查看>>
php 审计 for linux,for linux是什么意思
查看>>
matlab里面连接器是什么,Oops - an error has occurred
查看>>
matlab建立桌面图标,在ubuntu16.04上创建matlab的快捷方式(实现方法)
查看>>
smarty使用php代码,笑谈配置,使用Smarty技术_php
查看>>
oracle数据实际值限制,c# – Oracle数据库TNS密钥“数据源”的值长度超过了’128’的限制...
查看>>
silk v3 decoder php,解码转换QQ微信的SILK v3编码音频为MP3或其他格式
查看>>
linux不能访问80端口,lunux开放80端口(本地访问不了linux文件可能是这个原因)...
查看>>
android单位转换小程序,微信小程序中rpx与rem单位转换
查看>>
ps切图教程 android,PS前端切图完整教程
查看>>
html显示服务器状态,显示服务器时间并一直显示(html代码)
查看>>
在线html代码优化,网站seo优化html代码方法
查看>>
HTML如何把输入框变成必填值,required输入框为必填项
查看>>
html定位有几种,POSITION定位有哪几种?各有什么特点?
查看>>
背锅侠逆袭之路
查看>>
演示:使用协议分析器取证IPv6的报文结构
查看>>