爬虫实战 爬取谷歌图片 Google images

目标

#date:2020.5.25
#author:pmy
#aim:爬取google图片
本次爬取主要是为了练习selenium。

分析

爬取的目标如下图,爬取猫猫图片
在这里插入图片描述
将google图片顺利爬下来。
由于google图片界面是属于那种往下划会在本页面中加载出更多信息,但未刷新的机制,但是它又并未使用ajax。
所以这里我们使用selenium。selenium是一个能够模拟浏览器的工具,如果你没有安装,请pip install 一下。
然后是下载符合你的浏览器的驱动,我这里用的是Chrome,所以下载了ChromeDriver,将其放在D:\python\Scripts(你的python安装目录)。
用这两个来模拟用户的浏览器操作。


每次往下滑动500个单位,然后将当前窗口的所有图片的url抓取出来。
这里直接用selenium将tag_name为img的抓取出来就好了。
虽然可以先返回html文档,再用beautifulsoup来处理,但是这样繁琐,没有必要。同时因为该网页结构比较清晰,基本tag_name为img的就是我们的目标。


也存在一些问题,最前面几张图会抓取不了,因为它们的url并不是图片,而是打开是下图的界面
在这里插入图片描述
这和下面的所有图片不一样,下面的所有图片都是打开只有图片,这最前面的几张的url也特别特别长,无法下载图片,所以计算字符串的长度将其过滤。

同时,会将google的图标也抓下来。通过分析其他正常图片的url,发现其共性是其中都有images字符串,所以通过有无这个字符串来过滤。


因为每次抓取的图片只是当前窗口上显示的图片(selenium的特点),所以我们要设置一个列表,将抓取的url放进去,每次抓取时与列表进行比对,从而避免了重复爬取,不过效率偏低,不过用python还管啥效率(代码中写了可以修改的地方,我懒得改了,生命短暂)


因为对python其实也没怎么正式学过,所以这次用了面向对象的模式来写的代码,面向对象还是依然好用,下次需要的话可以直接调这个包。

完整代码

#date:2020.5.25
#author:pmy
#aim:爬取google图片from selenium import webdriver
import time
import os
import requests# 使用代理的方法 ,可以直接windows使用代理,不用这么麻烦
# browserOptions = webdriver.ChromeOptions()
# browserOptions.add_argument('--proxy-server=ip:port)
# browser = webdriver.Chrome(chrome_options=browserOptions)#修改keyword便可以修改搜索关键词
keyword = 'cat'
url = 'https://www.google.com.hk/search?q='+keyword+'&tbm=isch'class Crawler_google_images:# 初始化def __init__(self):self.url = url# 获得Chrome驱动,并访问urldef init_browser(self):chrome_options = webdriver.ChromeOptions()chrome_options.add_argument("--disable-infobars")browser = webdriver.Chrome(chrome_options=chrome_options)# 访问urlbrowser.get(self.url)# 最大化窗口,之后需要爬取窗口中所见的所有图片browser.maximize_window()return browser#下载图片def download_images(self, browser,round=2):picpath = './cat'# 路径不存在时创建一个if not os.path.exists(picpath): os.makedirs(picpath)# 记录下载过的图片地址,避免重复下载img_url_dic = []count = 0 #图片序号pos = 0for i in range(round):pos += 500# 向下滑动js = 'var q=document.documentElement.scrollTop=' + str(pos)browser.execute_script(js)time.sleep(1)# 找到图片# html = browser.page_source#也可以抓取当前页面的html文本,然后用beautifulsoup来抓取#直接通过tag_name来抓取是最简单的,比较方便img_elements = browser.find_elements_by_tag_name('img')#遍历抓到的webElementfor img_element in img_elements:img_url = img_element.get_attribute('src')# 前几个图片的url太长,不是图片的url,先过滤掉,爬后面的if isinstance(img_url, str):if len(img_url) <= 200:#将干扰的goole图标筛去if 'images' in img_url:#判断是否已经爬过,因为每次爬取当前窗口,或许会重复#实际上这里可以修改一下,将列表只存储上一次的url,这样可以节省开销,不过我懒得写了···if img_url not in img_url_dic:try:img_url_dic.append(img_url)#下载并保存图片到当前目录下filename = "./cat/" + str(count) + ".jpg"r = requests.get(img_url)with open(filename, 'wb') as f:f.write(r.content)f.close()count += 1print('this is '+str(count)+'st img')#防止反爬机制time.sleep(0.2)except:print('failure')def run(self):self.__init__()browser = self.init_browser()self.download_images(browser,10)#可以修改爬取的页面数,基本10页是100多张图片browser.close()print("爬取完成")if __name__ == '__main__':craw = Crawler_google_images()craw.run()

爬取结果

只爬了十轮,122张图片,可以修改main函数中的参数,爬取更多。
也可以修改keyword,爬取你想要的爬取的图片
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/28562.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python爬虫爬取Google图片

文章目录 urlliburllib.request.urlretrieve urllib3 in python3PoolManagerRequest BeautifulSoup安装 Installation一些函数 Some functionsget_textfind_all(name, attrs, recursive, string, limit, **kwargs)name - 通过标签名搜索kwargs - keyword arguments 关键字参数进…

Python——爬虫抓取图片

/* * Copyright (c) 2014, 烟台大学计算机学院 * All rights reserved. * 文件名称&#xff1a;test.cpp * 作 者&#xff1a;李晓凯 * 完成日期&#xff1a;2019年 8 月 19 日 * 版 本 号&#xff1a;v1.0 * * 问题描述&#xff1a; * 输入描述&#xff1a; * 程…

python爬虫(爬取图片)

在家无聊写的爬虫程序&#xff0c;用来爬取图片&#xff0c;由于这个是好久之前写的&#xff0c;有点忘了&#xff0c;写的不详细&#xff0c;后面再写一份详细的 爬虫的基本原理就是&#xff1a; 发起请求->获取响应->解析内容->保存数据 第一步&#xff1a;发…

面试常见题(荷兰国旗问题

面试常见题&#xff0c;荷兰三色国旗问题 挺有意思的 #include<bits/stdc.h> using namespace std; int main(){vector<int>str{2, 3, 1, 9, 7, 6, 1, 4, 5,4};int nstr.size();int target4;int l-1,rn;int p0;//这里不能是l<r哦&#xff0c;p代表数组遍历指针…

快速排序之荷兰国旗问题

描述 荷兰国旗有三横条块构成&#xff0c;自上到下的三条块颜色依次为红、白、蓝。现有若干由红、白、蓝三种颜色的条块序列&#xff0c;要将它们重新排列使所有相同颜色的条块在一起。本问题要求将所有红色的条块放最左边、所有白色的条块放中间、所有蓝色的条块放最右边。 …

从糖尿病捆绑支付看荷兰整合医疗

来源:中国数字科技馆 所谓捆绑支付模式,是指对于患有特定疾病的患者,在涉及多个照护提供方的时候,通过单一途径即可支付所接受的所有服务。在荷兰,随着老年人口及慢性疾病患者的增加,整合医疗开始受到政策决策者和保健提供者的关注,并将整合医疗定位为有前瞻性的、多学…

荷兰旗问题(三色旗排序)

摘要&#xff1a; 荷兰旗问题是三色排序&#xff0c;即某一组数据&#xff0c;元素的值只能为a,b ,c。把这组数据按照a, b, c的顺序排序。 本文介绍了一种时间复杂度为O&#xff08;n&#xff09;&#xff0c;空间复杂度O&#xff08;1&#xff09;的算法。 1. 问题描述 某…

荷兰国旗问题(分三块)

在说 “荷兰国旗” 问题之前&#xff0c;首先来看一个引例。 给定一个数组arr&#xff0c;和一个数num&#xff0c;请把小于等于num的数放在数组的左边&#xff0c;大于num的数放在数组的右边。要求额外空间复杂度O(1&#xff09;,时间复杂度 O(N&#xff09; 分析&#xff1…

荷兰国旗问题

Cousera Algorithms PartI第二周课后问答题&#xff0c;有这样一道题&#xff0c;当时没什么想法&#xff0c;直到学了第三周的归并排序&#xff0c;才弄明白要怎么做&#xff0c;这里记录一下自己的想法与最终代码。 问题描述 简而言之&#xff0c;这道题就是有红白蓝三种颜…

算法:荷兰国旗问题

什么是荷兰国旗问题 荷兰国旗是由红白蓝3种颜色的条纹拼接而成&#xff0c;如下图所示&#xff1a; 假设这样的条纹有多条&#xff0c;且各种颜色的数量不一&#xff0c;并且随机组成了一个新的图形&#xff0c;新的图形可能如下图所示&#xff0c;但是绝非只有这一种情况&am…

快排-荷兰国旗

在使用partition-exchange排序算法时&#xff0c;如快速排序算法&#xff0c;我们会遇到一些问题&#xff0c;比如重复元素太多&#xff0c;降低了效率&#xff0c;在每次递归中&#xff0c;左边部分是空的(没有元素比关键元素小)&#xff0c;而右边部分只能一个一个递减移动。…

BUUCTF 荷兰宽带数据泄露

题目 RouterPassView RouterPassView官方下载-RouterPassView中文免费版-华军软件园 ​ RouterPassView,大多数现代路由器允许您备份到一个文件路由器的配置&#xff0c;然后从文件中恢复配置时的需要。路由器的备份文件通常包含了像您的ISP的用户名重要数据/密码&#xff0c…

荷兰国旗问题以及快速排序

文章目录 一、荷兰国旗问题1、啥是荷兰国旗问题2、荷兰国旗问题的抽象3、解决的思路4、详细的参考代码 二、快速排序1、啥是快排&#xff08;排序流程&#xff09;2、抽象后的快排流程3、详细的参考代码 大家好&#xff0c;我是周一。 最近几篇算法&#xff0c;我们都是聊的归…

拍卖理论 英式拍卖 和 荷兰式拍卖 是什么

拍卖理论 源自Vickrey&#xff08;1961&#xff09;的早期研究&#xff0c;其因此获得1996年的诺贝尔经济学奖。 目标一般为&#xff1a;拍卖人的收益最大化、社会的整体效率最优化 对科研和商业方面有非常价值 英式拍卖 又称增价拍卖。拍品的起拍价格即最低期望价格&#…

谈腾讯地图web api如何实现类似百度地图内置的城市切换、关键字输入提示功能

PC WEB端新增客户的时候需要填写客户地址和联系人信息&#xff0c;包括&#xff1a;省市区、街道、详细地址和经纬度以及联系人、固话和移动电话。获取客户地址信息之前用的是百度地图&#xff0c;由于小程序中客户拜访时&#xff0c;需要对客户进行定位、距离计算&#xff0c;…

数学系列 (二)自然数、分数、小数、算数、代数

从无到有 数的概念 出生不久的孩子你觉的他认识1、2、3类似的数字吗&#xff1f;应该都不知道&#xff0c;可见数字的概念也是随着我们人类成长逐渐认识到的&#xff0c;英国经济学创立者亚当斯密说“数是人类在精神上制造出来的最抽象的概念”&#xff0c;属于逻辑思维里面的…

html 省份,城市 选择器附效果图

开发交流QQ群: 173683895 173683895 526474645 人满的请加其它群 效果图&#xff1a; 源码&#xff1a; <!DOCTYPE html> <html><head><meta charset"UTF-8"><link href"https://cdn.bootcss.com/bootstrap/3.3.7/css/boots…

深圳前海和后海的地理位置划分

前海后海的地理位置 前海和后海主要是相对于珠江口而言的&#xff0c;面向珠江口的为前海&#xff0c;背向珠江口的为后海或面向深圳湾的为后海。 前海知识拓展 https://www.sohu.com/a/490380431_124752

Python实现天气查询功能(外加Excel技巧)

昨天在网上发现了一个非常方便的天气API&#xff0c;就用Python试着用了一下。参数是挺少的&#xff0c;用起来也方便&#xff0c;但是那个城市代码确实是搞了我好长时间。 一、介绍 我们先来看一下实现的程序有什么功能&#xff1a; 功能也是非常简单的&#xff0c;输入城市…

找零钱问题——贪心算法

蓝桥杯——算法训练——找零钱 有n个人正在饭堂排队买海北鸡饭。每份海北鸡饭要25元。奇怪的是&#xff0c;每个人手里只有一张钞票&#xff08;每张钞票的面值为25、50、100元&#xff09;&#xff0c;而且饭堂阿姨一开始没有任何零钱。请问饭堂阿姨能否给所有人找零&#xf…