python抓取网页图片示例(python爬虫)

时间:2021-06-10 18:43:15 


#-*- encoding: utf-8 -*-
'''
Created on 2014-4-24

@author: Leon Wong
'''

import urllib2
import urllib
import re
import time
import os
import uuid

#获取二级页面url
def findUrl2(html):
    re1 = r'http://tuchong.com/\d+/\d+/|http://\w+(?<!photos).tuchong.com/\d+/'
    url2list = re.findall(re1,html)
    url2lstfltr = list(set(url2list))
    url2lstfltr.sort(key=url2list.index)
    #print url2lstfltr
    return url2lstfltr

#获取html文本
def getHtml(url):
    html = urllib2.urlopen(url).read().decode('utf-8')#解码为utf-8
    return html

#下载图片到本地
def download(html_page , pageNo):  
    #定义文件夹的名字
    x = time.localtime(time.time())
    foldername = str(x.__getattribute__("tm_year"))+"-"+str(x.__getattribute__("tm_mon"))+"-"+str(x.__getattribute__("tm_mday"))
    re2=r'http://photos.tuchong.com/.+/f/.+\.jpg'
    imglist=re.findall(re2,html_page)
    print imglist
    download_img=None
    for imgurl in imglist:
        picpath = 'D:\\TuChong\\%s\\%s'  % (foldername,str(pageNo))
        filename = str(uuid.uuid1())
        if not os.path.exists(picpath):
            os.makedirs(picpath)              
        target = picpath+"\\%s.jpg" % filename
        print "The photos location is:"+target
        download_img = urllib.urlretrieve(imgurl, target)#将图片下载到指定路径中
        time.sleep(1)
        print(imgurl)
    return download_img


# def callback(blocknum, blocksize, totalsize):
#     '''回调函数
#     @blocknum: 已经下载的数据块
#     @blocksize: 数据块的大小
#     @totalsize: 远程文件的大小
#     '''
#     print str(blocknum),str(blocksize),str(totalsize)
#     if blocknum * blocksize >= totalsize:
#         print '下载完成'

def quitit():
    print "Bye!"
    exit(0)
   

if __name__ == '__main__':
    print '''            *****************************************
            **    Welcome to Spider for TUCHONG    **
            **      Created on 2014-4-24           **
            **      @author: Leon Wong             **
            *****************************************'''
    pageNo = raw_input("Input the page number you want to scratch (1-100),please input 'quit' if you want to quit>")
    while not pageNo.isdigit() or int(pageNo) > 100 :
        if pageNo == 'quit':quitit()
        print "Param is invalid , please try again."
        pageNo = raw_input("Input the page number you want to scratch >")

    #针对图虫人像模块来爬取
    html = getHtml("http://tuchong.com/tags/%E4%BA%BA%E5%83%8F/?page="+str(pageNo))

    detllst = findUrl2(html)
    for detail in detllst:
        html2 = getHtml(detail)
        download(html2,pageNo)
    print "Finished."

标签:python,网页,爬虫
0
投稿

猜你喜欢

  • CentOS系统中PHP和MySQL的升级方法

    2023-11-20 21:04:19
  • python计算N天之后日期的方法

    2022-04-20 10:33:51
  • 微软建议的ASP性能优化28条守则(5)

    2008-02-27 13:54:00
  • 用VB将ASP代码封装成DLL

    2007-09-28 12:46:00
  • 如何利用触发器实现两个数据库间的同步

    2009-01-06 11:26:00
  • Pytorch如何把Tensor转化成图像可视化

    2021-11-03 20:20:22
  • CentOS7安装Python3的教程详解

    2023-10-17 02:40:28
  • 何处安放的Loading

    2011-08-10 19:11:20
  • Python excel合并居中值相同的单元格实例代码

    2021-09-24 13:40:47
  • 用Dreamweaver设计限时自动关闭网页

    2009-07-10 13:13:00
  • 自适应网页设计(Responsive Web Design)

    2012-05-02 10:49:07
  • Oracle故障处理Rman-06207&Rman-06214的方法

    2023-07-08 01:26:29
  • Centos7下编译安装配置Nginx+PHP+MySql环境

    2023-11-14 19:10:06
  • python卸载后再次安装遇到的问题解决

    2022-06-10 01:58:09
  • python实现的config文件读写功能示例

    2021-10-11 07:28:04
  • np.newaxis()函数的具体使用

    2022-01-10 08:38:27
  • Python之批量创建文件的实例讲解

    2021-04-10 15:17:08
  • python监控nginx端口和进程状态

    2023-08-25 16:15:13
  • python通过伪装头部数据抵抗反爬虫的实例

    2022-03-11 09:56:04
  • Dreamweaver打造多彩文字链接

    2007-11-11 18:59:00
  • asp之家 网络编程 m.aspxhome.com