qpython3使用手册图片_Python爬虫简单实现之Q乐园图片下载

本文主要是介绍qpython3使用手册图片_Python爬虫简单实现之Q乐园图片下载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

根据需求写代码实现。然而跟我并没有什么关系,我只是打开电脑望着屏幕想着去干点什么,于是有了这个所谓的“需求”。

终于,我发现了Q乐园——到底是我老了还是我小了,这是什么神奇的网站,没听过啊,就是下面酱紫儿——

980772-20171016193223318-2024028616.jpg

(虽然小广告有点多,一度以为这并不是什么“正经”的网站...)

我并不是二次元,只是觉得动漫图片还算是“老少皆宜”(“少儿不宜”多尴尬),就决定爬一下动漫图片好了。就是下面那个样子:

980772-20171016193525381-909796746.jpg

鼠标右键——查看源代码,别问我用得什么浏览器。网页大概就是下面这个样:

980772-20171016193542990-529438515.jpg

我好像看到了图集名称,“窗外繁华盛开”(窗内我一口老血),“你已经有别的小朋友了 我自己回家就好啦”(说好的老少皆宜,已经隐隐感受了到了早*的味道)

点开一个图集,看下“窗外繁华盛开”吧,还算美~

980772-20171016193634115-1855005710.jpg

980772-20171016193642771-71179216.jpg

然后我们还是右键查看源代码(说了不告诉你我用的什么浏览器)——

980772-20171016193712896-2636264.jpg

里面的“http://略略略略略略.jpg”就是图集中图片对应的地址了,比如http://v1.qzone.cc/pic/201709/27/14/13/59cb41a204354684.jpeg!600x600.jpg,直接复制到浏览器中打开就是图片了——不信试试!

所以,我们要下载图片,其实也就是要拿到这些网址。怎么拿?正则表达式,华丽登场!

就比如,我们如果打开了图集“窗外繁华盛开”,那就可以直接爬取图集中图片的地址了,这一个图集就搞定了。如果我们贪得无厌,想要下载更多图集的图片怎么办?(请依次打开图集,然后把鼠标放在图片上,右键图片另存为——啊,当然是开玩笑的了,毕竟我这么懒!)

所以呢,我们还要获取所有图集的网址。基本思路就是:打开一个图集网址——获取图片链接——图片下载——打开下一个图集网址——(这不是废话吗?)

那么,如何获取所有图集网址呢?

其实,我们第一次查看源代码的时候提到,好像已经看到了图集的名称,是的,图集的名称,再回头去看看,里面的确已经包含了图集的网址和名称了。举个栗子:

窗外繁花盛开

这一行里,/haokan/dongman/1349139.html这部分对应的就是网址,名称自己看。

好了,和获取图片网址一样,爬呗,反正我们有个不怕累的虫子(啊?虫子又是什么?我是谁?我在哪里?我在干什么?)

现在我们看到的是第一页,如果我们还想下载第二页、第三页、...所有页面的图集怎么办?(下载了有啥用?大概有病)

980772-20171016193736427-1199047260.jpg

看来我们只好手动一个一个页面的打开,然后“放虫咬图”!(pi~)

好吧,还是偷懒一下好了。反正我们就是下载Q乐园(高端大气上档次!)中的动漫图片,我们发现它的网页都是有规律的:比如第一页的网址:http://www.qzone.cc/haokan/dongman/,第二页的网址:http://www.qzone.cc/haokan/dongman/list_2.html。我猜第三页的网址是:http://www.qzone.cc/haokan/dongman/list_3.html(麻德,我好聪明怎么办?!)

于是网址我们可以通过列表的方式构造了。(列表!终于听到了一个正常的词儿,但其实我,根本没用到好吗啊啊啊啊)

所以,思路很简单了,我们先构造所有页面的网址集合,对每个页面网址爬取该页面上图集的网址,然后从图集的网址上爬取该图集包含的图片的网址,然后下载图片。(感觉好轻松!其实就是好轻松)

有几个小tips:

1.我不想把所有图片都扔到一个文件夹中,我想按照图集的名称分别创建文件夹,然后分别保存。怎么办?爬取图集名称创建文件夹呗~

2.图集名称中包含特殊字符,创建文件夹时很可能会因命名问题出错,那么怎么办?随便吧。。。我就随便一搞,差不多就行。

3.我发现页面源代码中没有包含一共多少页面,那么我们怎么判断一共要抓去多少页面呢?我猜大概不会出现http://www.qzone.cc/haokan/dongman/list_10000.html,一万页,这渣网,下到啥时候啊。嗯,还是随便吧,我就是随便一搞,真的差不多就行

4.如果有一张图片,或者有一个网页卡了,就是下载不下来或者打不开了怎么办?随便搞搞吧,定个时间,没反应劳资还不看了,跳过!

5.如果图集重复了,我想下载到同一个文件夹中,还不想覆盖原有的图片怎么办?我猜你肯定知道随便搞搞就行,你比我聪明!

6.我忘记了...

看我“自由派”的代码吧,大概会编程的人都受不了,框架结构什么的随便了,反正我乐意(斜眼)。直接跳过V1.0,V2.0,看V3.0吧!(建议V3.0也不用看,啥用啊)

V1.0

#Q乐园图片下载

#载入模块:路径设置、爬虫、正则表达式

importosimporturllibimportre#定义函数#页面抓取函数

defgetHTML(url, dec):

html=urllib.request.urlopen(url).read()

html=html.decode(dec)returnhtml#网页列表获取

defHtmlToList(html, s):

pat=re.compile(s)

ToList=pat.findall(html)returnToList#页面执行函数(图片下载)

defgetIMG(url, path, name):

imgpath= path+name+'.jpg'

print('正在下载第%s张照片...'%name)

urllib.request.urlretrieve(url, imgpath)#自定义创建文件夹的函数

defmakeDir(path, name):

topath= path+name

flag=Falseif notos.path.isdir(topath):

os.mkdir(topath)print('创建文件夹:%s!'%name)else:

flag=True

topath= topath+'\\'

returntopath,flag#初始页面(第一页)网址

url = r'http://www.qzone.cc/haokan/dongman/'

#正则表达式:匹配每页上的图集网址

SetS = r'

(.+?)
'

#获取页面上图集网址集合

html = getHTML(url, 'UTF-8')

PicSetlist=HtmlToList(html, SetS)#文件夹准备

path = 'D:\\QLeYuan\\'name= 'PicSet'

#正则表达式:在图集网页中匹配图片

PicS = r'original="(http://.+?/.+?/.+?/.+?/.+?/.+?/.+?.jpg)" class="lazy"'

#第一页图集下载

for bit,dirname inPicSetlist:#创建图集路径文件夹

dirname.replace('?','')

dirpath= path+name+'\\'filepath,flag=makeDir(dirpath, dirname)#组合图集url

seturl = url+bit#获取图片列表

html = getHTML(seturl, 'UTF-8')

PicList=HtmlToList(html, PicS)#图片名称

imgname =0for PicUrl inPicList:#如果获取的图集名称重复,那么下载到同一文件夹中并重命名,避免出现同名文件无法创建的问题

ifflag:

picname= '1-'+str(imgname)else:

picname=str(imgname)#获取图片

getIMG(PicUrl, filepath, picname)

imgname= imgname+1

V2.0

#Q乐园图片下载

#载入模块:路径设置、爬虫、正则表达式

importosimporturllibimportre#设置超时处理

importsocket#定义函数#页面抓取函数

defgetHTML(url, dec):

html=urllib.request.urlopen(url).read()

html=html.decode(dec)returnhtml#网页列表获取

defHtmlToList(html, s):

pat=re.compile(s)

ToList=pat.findall(html)returnToList#页面执行函数(图片下载)

defgetIMG(url, path, name):

imgpath= path+name+'.jpg'urllib.request.urlretrieve(url, imgpath)#自定义创建文件夹的函数

defmakeDir(path, name):

topath= path+name

flag=Falseif notos.path.isdir(topath):print('创建文件夹:%s!'%dirname)

os.mkdir(topath)else:

flag=True

topath= topath+'\\'

returntopath,flag#初始页面(第一页)网址

url_1 = r'http://www.qzone.cc/haokan/dongman/'

#文件夹准备

path = 'D:\\QLeYuan\\'name= 'PicSet'

#正则表达式:匹配每页上的图集网址

SetS = r'

(.+?)
'

#正则表达式:匹配所有页面网址

UrlS = r'.'

#获取页面网址

html = getHTML(url_1, 'UTF-8')

UrlList=HtmlToList(html, UrlS)#构造第一页的网址

UrlList.insert(0,'')for root inUrlList:

url= url_1+root#获取页面上图集网址集合

html = getHTML(url, 'UTF-8')

PicSetList=HtmlToList(html, SetS)#正则表达式:在图集网页中匹配图片

PicS = r'original="(http://.+?/.+?/.+?/.+?/.+?/.+?/.+?.jpg)" class="lazy"'

#第一页图集下载

for bit,dirname inPicSetList:#创建图集路径文件夹

dirname = dirname.replace('?','')

dirname= dirname.replace('\\','')

dirpath= path+name+'\\'filepath,flag=makeDir(dirpath, dirname)#组合图集url

seturl = url_1+bit#获取图片列表

html = getHTML(seturl, 'UTF-8')

PicList=HtmlToList(html, PicS)#图片名称

imgname =0for PicUrl inPicList:#如果获取的图集名称重复,那么下载到同一文件夹中并重命名,避免出现同名文件无法创建的问题

ifflag:

picname= '1-'+str(imgname)else:

picname=str(imgname)#获取图片:如果遇到下载异常会提示

try:#下载超时会报错跳过该异常下载其他

socket.setdefaulttimeout(5.0)print('正在下载第%s张照片...'%picname)

getIMG(PicUrl, filepath, picname)except:print('图片%d下载异常'%imgname)

imgname= imgname+1

print('下载完成!')

V3.0

#Q乐园图片下载

#载入模块:路径设置、爬虫、正则表达式

importosimporturllibimportre#设置超时处理

importsocket#定义函数#页面抓取函数

defgetHTML(url, dec):

html=urllib.request.urlopen(url).read()

html=html.decode(dec)returnhtml#网页列表获取

defHtmlToList(html, s):

pat=re.compile(s)

ToList=pat.findall(html)returnToList#页面执行函数(图片下载)

defgetIMG(url, path, name):

imgpath= path+name+'.jpg'urllib.request.urlretrieve(url, imgpath)#自定义创建文件夹的函数

defmakeDir(path, name):

topath= path+name

flag=Falseif notos.path.isdir(topath):print('创建文件夹:%s!'%dirname)

os.mkdir(topath)else:

flag=True

topath= topath+'\\'

returntopath,flag#检查文件夹名是否合法

def checkDirName(name=None):if name isNone:print('name is None.')

s= r'[;\\/:*?"<>|\r\n]+'pat=re.compile(s)

bug=pat.findall(name)ifbug:for char inbug:

name= name.replace(char, '_')returnname#初始页面(第一页)网址

url_1 = r'http://www.qzone.cc/haokan/dongman/'url=url_1#文件夹准备

path = 'D:\\QLeYuan\\'name= 'PicSet'

#正则表达式:匹配每页上的图集网址

SetS = r'

(.+?)
'

#图集名称重复下载到同一文件夹

namesame = 1label=True

root= 2

whilelabel:try:#获取页面上图集网址集合

html = getHTML(url, 'UTF-8')

PicSetList=HtmlToList(html, SetS)except:print('下载所有页面已下载完成!或者打开网址出错!')break

#正则表达式:在图集网页中匹配图片

PicS = r'original="(http://.+?/.+?/.+?/.+?/.+?/.+?/.+?.jpg)" class="lazy"'

#第一页图集下载

print('正在下载第%d页图集:'%(root-1))for bit,dirname inPicSetList:#创建图集路径文件夹

dirname =checkDirName(dirname)

dirpath= path+name+'\\'filepath,flag=makeDir(dirpath, dirname)#组合图集url

seturl = url_1+bit#获取图片列表

html = getHTML(seturl, 'UTF-8')

PicList=HtmlToList(html, PicS)#图片名称

imgname =0ifflag:

prename= str(namesame)+'_'namesame= namesame+1

else:

namesame= 1prename= ''

for PicUrl inPicList:#如果获取的图集名称重复,那么下载到同一文件夹中并重命名,避免出现同名文件无法创建的问题

picname = prename+str(imgname)#获取图片:如果遇到下载异常会提示

try:#下载超时会报错跳过该异常下载其他

socket.setdefaulttimeout(5.0)print('正在下载第%s张照片...'%picname)

getIMG(PicUrl, filepath, picname)except:print('图片%d下载异常'%imgname)

imgname= imgname+1

#更新网址

url = url_1+'list_'+str(root)+'.html'root= root+1

(可以搞一搞,不止下载动漫图片,下载所有的类型的图片,不难实现。实在没有什么意思了...)

那么,下载了图集长什么样子呢?

先看下下载过程大概长什么样子(其实根本没有过程):

980772-20171016193800849-35175934.jpg

下载后部分文件夹:

980772-20171016193812349-884796672.jpg

看看“窗外繁华盛开”,图片是什么样子:

980772-20171016193835631-584337285.jpg

我没有实际运行到最后结束(毕竟渣网速)。我尝试不实际下载图片,只看共有多少个图集,大概有两三千不是问题,平均一个图集5张图片的话,一万张图片都是妥妥的。

好像压根没有说到正则表达式是什么,爬虫是什么,实现技巧是什么...别问我,反正我也不知道是什么。还有,别问我是什么浏览器,因为这并不重要,反正什么浏览器都行(白眼)

千万不要把这当做是教程,这大概只是理科生的一篇“随笔”,吐槽一下近期的部分心情(强调是部分!)。开心就好啊~

最后,正经说一句:如有侵权,请联系删除!(麻德,我侵了谁的权,惊恐)

这篇关于qpython3使用手册图片_Python爬虫简单实现之Q乐园图片下载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/393492

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo