专栏名称: 养码场
养码场,一个技术人职场社交平台。 现有“养码人”80000+,覆盖JAVA/PHP/iOS/测试/运维等领域。80%级别在P6及以上,含P9技术大咖30人,技术总监和CTO 500余人。
目录
相关文章推荐
爱否科技  ·  轻薄是未来?腰线十几块?N4 去哪了?AI ... ·  3 天前  
爱否科技  ·  REDMI ... ·  5 天前  
爱否科技  ·  iPhone SE 4 或改命 ... ·  5 天前  
凰家评测  ·  OPPO Find ... ·  4 天前  
51好读  ›  专栏  ›  养码场

用Python解读“女神大会”,直男心目中的女神是这样的?

养码场  · 公众号  ·  · 2019-01-22 16:36

正文

都说直男审美不可靠,而程序员作为直男一大代表,更是经常被调侃穿衣风格、外在形象。但场主发现, 直男(程序员)的审美,似乎,还是有点靠谱的?


今天给大家分享的这篇文章,作者 :徐麟,目前就职于互联网公司数据部,哥大统计数据狗,从事数据挖掘&分析工作,喜欢用R&Python玩一些不一样的数据。



作为一位喜爱足球的球迷,“懂球帝”一定会是款必不可少的 app,即使是只有 16G 的空间,也从未将其卸载。


然而我们今天聊的与足球无关,而是去聊懂球帝上的“女神大会”专栏,作为一个大型“钢铁直男”聚集地,“懂球帝”上对各位女神的评分,对广大“钢铁直男”群体也具有一定代表性。



数据来源


目前女神大会更新至了第 90 期,总共出场了 90 位女神,界面如下:



我们通过 fiddler 获取该界面中女神的照片地址以及每一篇文章的 id 编号,用于之后的爬取和可视化,代码如下:


1import json
2import requests
3from bs4 import BeautifulSoup
4import pandas as pd
5import re
6import os
7os.chdir('D:/爬虫/女神')
8
9id_list = []
10title_list = []
11pic_list = []
12date_list=[]
13
14for i in range(1,6):
15   url= 'http://api.dongqiudi.com/search?keywords=%E5%A5%B3%E7%A5%9E%E5%A4%A7%E4%BC%9A&type=all&page='+str(i) 
16   html = requests.get(url=url).content
17   news = json.loads(html.decode('utf-8'))['news']
18   this_id = [k['id'for k in news]
19   this_pic = [k['thumb'for k in news]
20   this_title = [k['title'for k in news]
21   this_date = [k['pubdate'for k in news]
22   this_title=[BeautifulSoup(k,"html.parser").text for k in this_title]
23   id_list = id_list+this_id
24   title_list = title_list+this_title
25   pic_list = pic_list+this_pic
26   date_list = date_list+this_date


另一方面,每位女神的评分都在下一期当中,我们需要爬取文章内容进行获取:



爬取代码如下:


1prev_title_list = []
2score_list=[]
3count_list=[]
4for id in id_list:
5   url = 'http://www.dongqiudi.com/archive/{k}.html'.format(k=id)    
6   header = {'User-Agent''Mozilla/5.0 (Windows NT 10.0; Win32; x32; rv:54.0) Gecko/20100101 Firefox/54.0',
7   'Connection''keep-alive'}
8   cookies ='v=3; iuuid=1A6E888B4A4B29B16FBA1299108DBE9CDCB327A9713C232B36E4DB4FF222CF03; webp=true; ci=1%2C%E5%8C%97%E4%BA%AC; __guid=26581345.3954606544145667000.1530879049181.8303; _lxsdk_cuid=1646f808301c8-0a4e19f5421593-5d4e211f-100200-1646f808302c8; _lxsdk=1A6E888B4A4B29B16FBA1299108DBE9CDCB327A9713C232B36E4DB4FF222CF03; monitor_count=1; _lxsdk_s=16472ee89ec-de2-f91-ed0%7C%7C5; __mta=189118996.1530879050545.1530936763555.1530937843742.18'
9   cookie = {}
10   for line in cookies.split(';'):
11       name, value = cookies.strip().split('='1)
12       cookie[name] = value    
13   html = requests.get(url,cookies=cookie, headers=header).content
14   try:
15       content = BeautifulSoup(html.decode('utf-8'),"html.parser")
16       score = content.find('span',attrs={'style':"color:#ff0000"}).text
17       prev_title = content.find('a',attrs={"target""_self"}).text
18       prev_title_list.append(prev_title)
19       score_list.append(score)
20       sentence = content.text.split(',')
21       count=[k for k in sentence if re.search('截至目前',str(k))][0]
22       count_list.append(count)
23   except:
24       continue




整体对比


我们此次利用R语言中的 ggimage 包,将获取到的女神图片加入到最终的图表中,提高可视化效果,首先看一下 整体评分的 TOP15 名单



朱茵、林志玲、高圆圆位居榜单前三位,不知道这份榜单是否符合你心目中的女神标准,而这三位也恰好成为了目前出场的 90 位女星当中香港、台湾、大陆的最高分。


值得一提的是,懂球帝小编对于活跃于 90 年代的香港女星情有独钟,从中选取了非常多的女神,而这些女神的评分也都名列前茅。


下面看一下 目前出场的 90 位女神中,排名相对靠后的几位




很多朋友会觉得这份榜单对于年轻女神有些苛刻,可能这也代表了广大网友对于各位年轻女神的美好期许,体现了她们未来的无限可能。



区域对比


我们分区域看一下目前 各个区域排名前十的名单






(以上图片均来自于“懂球帝”APP)



看完了各个区域 TOP10 的名单之后,我们进行一下区域的对比:



我们将小提琴图与盒形图相结合,进行区域的对比,可以看到大陆女星的评分相对偏低,一方面是由于部分女神的评分较低,拉低了整体的分值,另一方面也是由于目前出场的大陆女星年龄普遍偏小,而这一点也会在下一部分得到证实。



年份对比








请到「今天看啥」查看全文