爬了下Unsplash上的高清壁纸,总有一款适合你

欢迎关注天善智能,我们是专注于商业智能BI,人工智能AI,大数据分析与挖掘领域的垂直社区,学习,问答、求职一站式搞定!

对商业智能BI、大数据分析挖掘、机器学习,python,R等数据领域感兴趣的同学加微信:tstoutiao,邀请你进入数据爱好者交流群,数据爱好者们都在这儿。

作者:强哥,现供职于一家大型全球电子商务网站,多年Python程序员,热爱数据,热爱AI,希望能与更多同业人交流。

个人公众号:Python与数据分析

Unsplash是个高清摄影图片的网站,里面的照片非常精美,分辨率也很高,最重要的是,所有的照片都没有版权,无须向原作者申请授权,即可任意使用。

最近闲暇的时候写了个爬虫爬了下Unsplash上的那些高赞的壁纸。爬虫原理非常简单,就是爬取所有的壁纸,然后筛选那些赞数最高的图片。

代码实现

第一步我们爬取Unsplash所有的壁纸图片信息,并存入MongoDB,代码如下

defget_image_by_page(page_no):url="https://unsplash.com/napi/collections/1065976/photos?page={}&per_page=10&order_by=latest&share_key=a4a197fc196734b74c9d87e48cc86838".format(page_no)r=requests.get(url,verify=False)data=r.json()returndatadefget_images():page_no=1client=pymongo.MongoClient()db=client["unsplash"]whileTrue:result=get_image_by_page(page_no)iflen(result)==0:breakdb.wallpaper.insert_many(result)print(page_no)page_no+=1time.sleep(10)

爬下来的数据里面包含了几个重要的字段。

我们最关心的就是likes这个字段,这个里面存了图片的赞数,后续我们筛选高赞图片的时候会用到。

还有两个字段分别是width和height,这是图片的宽度和高度,因为我们这里关注的是桌面壁纸,所以只关心宽度大于高度的那些壁纸。

爬完图片信息后,接下来我们从数据库筛选高赞图片,代码如下

defget_top_liked_images():client=pymongo.MongoClient()db=client["unsplash"]cursor=db.wallpaper.aggregate([{"$match":{"likes":{"$gte":1000}}}])path=os.path.dirname(__file__)path=os.path.join(path,"wallpaper")foritemincursor:url=item["urls"]["raw"]width=item["width"]height=item["height"]ifwidth<=height:continuer=requests.get(url,verify=False)filename="{}.jpg".format(int(time.time()))filepath=os.path.join(path,filename)withopen(filepath,"wb")asf:f.write(r.content)print(filepath)time.sleep(10)

这里我们会根据图片信息里的URL去下载图片。需要注意的是,如果过于频繁的爬取Unsplash,会导致爬虫被封,所以这里每次下载完都会睡个10秒钟。

高赞壁纸

我们从爬取的结果里面精选了80张高赞壁纸,没有加任何水印,放在这里。不过微信对上传的图片作了压缩,所以上传后的图片不是原图,分辨率有些损失。需要原图的话在文末有获取方式。

下面是80张无水印高赞壁纸,大家看看最喜欢哪一张呢,欢迎在留言里告诉我~

1

3901436-05816649e2283783

2

3901436-69005d661db84a35

3

3901436-a9904a7ff9943882

4

3901436-639ba975d0681d56

5

3901436-2421b26f790277a5

6

3901436-4a5efeae5f2610f9

7

3901436-27246055ca7d3c36

8

3901436-d1756564f93a7e4e

9

3901436-9d36501ef1408312

10

3901436-c82a39ab9922f59c

11

3901436-804376a3ea32d9f9

12

3901436-62513d6c79562f14

13

3901436-ebb62fba7dda961b

14

3901436-22cf65868fe90cdc

15

3901436-c2865c5380c09e31

16

3901436-aaa3021fbc94e068

17

3901436-e7895e3d7b51436e

18

3901436-b3b330d7af454875

19

3901436-55d0847ffd5a2560

20

3901436-935fae6b8b36643c

21

3901436-09007d54aa1331d5

22

3901436-028e3d8aed936c49

23

3901436-aa24e594d8bbc5ec

24

3901436-b5b870dc01bb398e

25

3901436-1452345e81e9762a

26

3901436-c93a28f496356852

27

3901436-8a6cff9c0673d2a7

28

3901436-6bfbad559d366d09

29

3901436-0c5cf29b5638f043

30

3901436-3dcf70589fd5e7f0

31

3901436-c47b5b0eceef14a8

32

3901436-b493480232057900

33

3901436-11827d4af19e3054

34

3901436-bf71bbe48a16d32f

35

3901436-13a573fd66afa42b

36

3901436-bad715ba161566e0

37

3901436-f35cbbcc79c8e024

38

3901436-a980f5eaafdec577

39

3901436-4c59fb15502fd8ea

40

3901436-86eeebb73ac008e1

41

3901436-486927de971a1ab3

42

3901436-2a87cb61c5ff4a35

43

3901436-a3218cd87a972dba

44

3901436-cff6325df7a3c258

45

3901436-bd3a140a5a44c279

46

3901436-62fe4c8fbf3e4b0e

47

3901436-beb3ab7665427fb6

48

3901436-759a0660fb92b076

49

3901436-3fa131d035d3c848

50

3901436-ab0c17015aab82e5

51

3901436-6e56d45cd448fa55

52

3901436-bca1c997d1c2db40

53

3901436-d36161a32f0cfedb

54

3901436-c30d483d2f58dd2d

55

3901436-399182a30dc05fc4

56

3901436-2a4f82047907f8a8

57

3901436-67bda2eea0e6d82d

58

3901436-26c2441d3c07da2a

59

3901436-3bcbda345b94a594

60

3901436-af205cdd9c9de364

61

3901436-e332425142e86d47

62

3901436-d6687f07aff84e00

63

3901436-dc2c834be7b1b9fe

64

3901436-b4762371ed641476

65

3901436-33dc87387c11f81d

66

3901436-90925af1f4dab5cc

67

3901436-cc206e0b5b5cfe4c

68

3901436-2c6281efc761aeda

69

3901436-60dd3d57b2f27fa8

70

3901436-1176f43e89369708

71

3901436-9df412031d1c130e

72

3901436-01026e9d7fef9a80

73

3901436-2b0dec4280d3293e

74

3901436-bb5dc4df3a8ec96d

75

3901436-8cf5adf203a6b4d1

76

3901436-ce7e901d0491d79b

77

3901436-9b0c52595aa6149c

78

3901436-b3e02a746154be26

79

3901436-209eaa7c160508ff

80

3901436-4a559b3c0a6b7130

完整代码已上传github,所有原图已上传百度网盘,可在公众号后台回复unsplash获取。

Python的爱好者社区历史文章大合集

2018年Python爱好者社区历史文章合集(作者篇)

福利:文末扫码关注公众号,“Python爱好者社区”,开始学习Python课程:

关注后在公众号内回复“ 课程 ”即可获取:

小编的转行入职数据科学(数据分析挖掘/机器学习方向)【最新免费】

小编的Python的入门免费视频课程

小编的Python的快速上手matplotlib可视化库!

崔老师爬虫实战案例免费学习视频。

陈老师数据分析报告扩展制作免费学习视频。

玩转大数据分析!Spark2.X + Python精华实战课程免费学习视频。

3901436-5e42f7469d28bf8d
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值