基于python做的抓图程序1.0.00版本

#coding=gbk
import urllib
import urllib2
import re
import os
import time
# import readline

def getHtml(url):
    #一些网站限制浏览器访问,python模拟浏览器
    heads = {'Accept':'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
            'Accept-Charset':'GB2312,utf-8;q=0.7,*;q=0.7',
            'Accept-Language':'zh-cn,zh;q=0.5',
            'Cache-Control':'max-age=0',
            'Connection':'keep-alive',
            'Host':'John',
            'Keep-Alive':'115',
            'Referer':url,
            'User-Agent':'Mozilla/5.0 (X11; U; Linux x86_64; zh-CN; rv:1.9.2.14) Gecko/20110221 Ubuntu/10.10 (maverick) Firefox/3.6.14'}
 
    opener = urllib2.build_opener(urllib2.HTTPCookieProcessor())
    urllib2.install_opener(opener)
    req = urllib2.Request(url)
    opener.addheaders = heads.items()
    respHtml = opener.open(req).read()
    # return respHtml.decode('gbk').encode('utf-8')
    return respHtml

def getImg(html):
#     reg = r'input src=\'*(.*?\.jpg)'
    reg = r'src="(.+?\.jpg)"'
    imgre = re.compile(reg)
    imglist = re.findall(imgre,html)
    # print(imglist)
    # return 1
    x = 0
    #生成临时目录存储
    createDir = 'getpic'+time.strftime('%Y%m%d%H%M%S')
    if not os.path.isdir(createDir) and not os.path.isfile(createDir):
       os.mkdir(createDir)
    # print(os.getcwd())
    os.chdir(createDir)
    # print(os.getcwd())
    for imgurl in imglist:
        print("正在抓取图片:"+imgurl)
        urllib.urlretrieve(imgurl,'%s.jpg' % x)
        x+=1
       
# readline.parse_and_bind("control-v: paste")
website = raw_input("please input website:")

html = getHtml(website)
# print(html)
getImg(html)

 

最近学习python,参考网上的资料做了抓图程序,目前还有以下几点要完善

1. 如何支持界面输入,比如支持多个 选项,输入多个url

2. 支持匹配列表,发现有些网站的匹配规则不一致,导致不能通用

3. winpython不支持readline模块,导致py2exe生成的cmd窗口需要设置后,才能粘贴网址

 

如果使用py2exe生成一个通用的exe文件

在工作目录创建文件 create.py,内容如下

from py2exe.build_exe import py2exe
from distutils.core import setup
from glob import glob 
import py2exe
import os, sys
import shutil
 
if len(sys.argv) == 1:
    sys.argv.append("py2exe")
     
includes = ["encodings", "encodings.*"]
options = {"py2exe": 
             {   "compressed": 1, 
                 "optimize": 2, 
                 "includes": includes, 
                 "dist_dir": "bin",
                 "bundle_files": 1 
             } 
           } 
setup(    
     version = "1.0", 
     description = u'To grab pictures',
     name = "grabpic1.0.00", 
     options = options, 
     zipfile = None, 
     console=[{"script": "grabpic1.0.00.py"}],   
     data_files=[]
     )
os.remove("bin//w9xpopen.exe")    
# shutil.rmtree("build")

使用命令python create.py py2exe ,生成文件后,在bin/grabpic1.0.00.exe

运行grabpic1.0.00.exe ,右键设置 看到中间有个插入模式,勾选,然后cmd窗口就可以贴图了。

PS:第一次写,不知道如何贴图,悲催

 

参考帖子:

http://blog.csdn.net/txg703003659/article/details/30459475

http://blog.csdn.net/linda1000/article/details/12909439

 

转载于:https://www.cnblogs.com/mutouxiaofei/p/5716958.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值