首页 编程教程正文

python小白第二次实践,爬壁纸

piaodoo 编程教程 2020-02-22 22:06:08 917 0 python教程

本文来源吾爱破解论坛

嘻嘻嘻,感谢大家昨天的评论和评分和鼓励,我会继续加油学习的,今天爬了个资源还不错壁纸网站,分享给大家,看不懂得地方,私聊评论,我看到了,一定回答,另外大佬们看到有优化简写的地方,也请多多指教,嘻嘻。
本来写循环可以下所有类目的,后来想了想,就改成选择数字了。废话不多说,上源码。[Asm] 纯文本查看 复制代码

# 作者:Administrator
# 日期:2019/7/28 11:39
# 工具:PyCharm
import requests
from lxml import etree
import os

class BiZhi(object):

    def first_request(self,headers,number):
        for j in range(1,2):
            url = 'http://www.win4000.com/mobile_'+str(number)+'_0_0_'+str(j)+'.html'
            response = requests.get(url,headers=headers)
            html = etree.HTML(response.content.decode())
            Bigtit_list = html.xpath('//ul[@class="clearfix"]/li/a/@title')
            Biglink_list = html.xpath('//div[@class=""]/ul/li/a/@href')
            for Bigtit,Biglink in zip(Bigtit_list,Biglink_list):
                if os.path.exists(Bigtit) == False:
                    os.mkdir(Bigtit)
                biglink = str(Biglink).replace('.html','')
                self.second_request(Bigtit,biglink,headers)

    def second_request(self,Bigtit,biglink,headers):#,Bigtit,Biglink,
        for i in range(1,10):
            try:
                url = biglink+'_'+str(i)+'.html'
                # if url == biglink+'_'+str(i+1)+'.html':
                #     break
                response = requests.get(url,headers=headers)
                html = etree.HTML(response.content.decode())
                img_link = ''.join(html.xpath('//div[@class="main-wrap"]/div/a/img/@src'))
                print(img_link)
                # 请求图片下载地址
                resp = requests.get(img_link,headers=headers)
                data = resp.content
                img_name = img_link[-10:]
                # print(img_name)
                file_name =Bigtit +'\\' +img_name
                print('正在下载的图片为:',img_name)
                with open(file_name,'wb') as f:
                    f.write(data)
            except Exception as err:
                if err == 'string index out of range':
                    continue



spider = BiZhi()
headers = {'User-Agent':'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0; Acoo Browser; SLCC1; .NET CLR 2.0.50727; Media Center PC 5.0; .NET CLR 3.0.04506)'}
print('''
以下为分类对应数字,输入是请输入数字!……^^_^^……
明星:2338  节日:2339  美女:2340
风景:2341  汽车:2342  可爱:2343
唯美:2344  动漫:2346  爱情:2347
动态:2348  卡通:2349  高翔:2350
影视:2354  动物:2355  植物:2356  美食:2362


''')
number = input('请输入您要下载类目对应的数字:')
spider.first_request(headers,number)


以图为证:

QQ截图20190728131700.png (33.7 KB, 下载次数: 2)

下载附件  保存到相册

2019-7-28 13:22 上传

文件夹

文件夹

QQ截图20190728131735.png (300.87 KB, 下载次数: 2)

下载附件  保存到相册

2019-7-28 13:22 上传

测试成功

测试成功

版权声明:

本站所有资源均为站长或网友整理自互联网或站长购买自互联网,站长无法分辨资源版权出自何处,所以不承担任何版权以及其他问题带来的法律责任,如有侵权或者其他问题请联系站长删除!站长QQ754403226 谢谢。

有关影视版权:本站只供百度云网盘资源,版权均属于影片公司所有,请在下载后24小时删除,切勿用于商业用途。本站所有资源信息均从互联网搜索而来,本站不对显示的内容承担责任,如您认为本站页面信息侵犯了您的权益,请附上版权证明邮件告知【754403226@qq.com】,在收到邮件后72小时内删除。本文链接:https://www.piaodoo.com/7529.html

搜索