python + pyqt 实现的你下载css背景图片的小工具(最终版)
学习python有三个星期了,算是做的第一个小工具,其实也没必要做成图形界面,只是为的GUI学习(再说技术总归给人使用的,熟练很多shell命令只是个“匠人”。)
win8下面:
ubutu 下:
虽是小工具,大版本有3个
1.命令行版
2.pyqt GUI版
3.pyqt GUI 线程版
期间也大大小小的bug修复n多次,几次重构(笑),算得上是“软件开发的小周期”吧。今天贴代码是是第3版:
saveCssImg.py
# coding: utf-8 -*- import urllib2,urllib
import sys,re,os,urlparse
from PyQt4 import QtCore, QtGui class saveCssBackImg(QtGui.QWidget):
updateSig = QtCore.pyqtSignal(str) def __init__(self,cssUrl,savePath,parent=None):
super(saveCssBackImg, self).__init__(parent)
self.cssUrl = cssUrl
self.savePath = mkdir(savePath) def saveImg(self):
counter = 1
errnum = 0
imgList = self.getImgList()
img_num = len(imgList) for img in imgList:
img = img.strip("'")
img = img.strip('"') if re.match('^https?://', img):
imgsrc = img.split('?')[0]
else:
imgsrc = urlparse.urljoin(self.cssUrl, img).split('?')[0] imgname = os.path.split(imgsrc)[1]
try:
httpcode = urllib.urlopen(imgsrc).code
except:
httpcode = None if httpcode == 200 :
try:
urllib.urlretrieve(imgsrc, os.path.join(self.savePath,imgname))
info = u'[%2d/%2d]<a href="%s">%s</a>' %( counter, img_num , imgsrc,imgsrc )
except:
errnum += 1
info = u'[%2d/%2d]<a href="%s">%s</a> <span style="color:red">保存失败[%s]</span>' %( counter, img_num , imgsrc ,imgsrc,errnum)
else:
errnum += 1
info = u'[%2d/%2d]<a href="%s">%s</a> <span style="color:red">[%s][code:%s]</span>' %( counter, img_num , imgsrc ,imgsrc ,errnum, httpcode) self.updateSig.emit(info)
counter+=1 def getImgList(self):
allimglist = re.findall(r'url\s*\((.*?)\)', self.getCssContent())
imgList = set(allimglist)
return imgList def getCssContent(self) :
try:
rsp = urllib2.urlopen(self.cssUrl,timeout = 1)
return rsp.read()
except urllib2.URLError, e:
self.updateSig.emit('<font color=red>%s</font>' % e ) except BaseException, e:
self.updateSig.emit('<font color=red>%s</font>' % e ) def mkdir(savePath):
fullPath = os.path.join(os.getcwd(),savePath)
if not os.path.exists(fullPath) :
try:
os.mkdir(os.path.join(os.getcwd(),savePath))
return fullPath
except:
print 'can\'t creat dir: %s, please creat it manually! ' % fullPath
return
return fullPath
project_ui.py
# coding: utf-8 -*- from PyQt4 import QtCore, QtGui
from saveCssImg import * try:
_fromUtf8 = QtCore.QString.fromUtf8
except AttributeError:
def _fromUtf8(s):
return s try:
_encoding = QtGui.QApplication.UnicodeUTF8
def _translate(context, text, disambig):
return QtGui.QApplication.translate(context, text, disambig, _encoding)
except AttributeError:
def _translate(context, text, disambig):
return QtGui.QApplication.translate(context, text, disambig) class UI_getImg(QtGui.QDialog):
def __init__(self, parent=None):
super(UI_getImg, self).__init__(parent)
self.setupUi(self)
self.lineEdit.setText('http://simg.sinajs.cn/blog7style/css/conf/blog/article.css')
self.textBrowser.setOpenExternalLinks(True)
self.textBrowser.setLineWrapMode(QtGui.QTextEdit.NoWrap)
self.textBrowser.setStyleSheet("QTextBrowser {background: #eee; }")
self.pushButton.clicked.connect(self.goWork) def goWork(self):
self.thread = WorkerThread()
self.thread.sinOut.connect(self.outText)
self.thread.finished.connect(self.workFinished) cssUrl = str(self.lineEdit.text())
savePath = 'downImgs' self.textBrowser.setText(u'CSS文件地址: <a href="%s">%s</a><br>__________<br>' % (cssUrl,cssUrl))
self.pushButton.setDisabled(True) self.thread.setEvr(cssUrl,savePath) def workFinished(self):
self.outText(u'<br>__________<br>已退出下载!')
self.pushButton.setDisabled(False) def setupUi(self, Dialog):
Dialog.setObjectName(_fromUtf8("Dialog"))
Dialog.resize(800, 407)
self.pushButton = QtGui.QPushButton(Dialog)
self.pushButton.setGeometry(QtCore.QRect(700, 20, 75, 23))
self.pushButton.setObjectName(_fromUtf8("pushButton"))
self.textBrowser = QtGui.QTextBrowser(Dialog)
self.textBrowser.setGeometry(QtCore.QRect(10, 60, 780, 341))
self.textBrowser.setObjectName(_fromUtf8("textBrowser"))
self.lineEdit = QtGui.QLineEdit(Dialog)
self.lineEdit.setGeometry(QtCore.QRect(10, 20, 670, 20))
self.lineEdit.setObjectName(_fromUtf8("lineEdit")) self.retranslateUi(Dialog)
QtCore.QMetaObject.connectSlotsByName(Dialog) def retranslateUi(self, Dialog):
Dialog.setWindowTitle(_translate("Dialog", "下载Css文件图片", None))
self.pushButton.setText(_translate("Dialog", "下载", None)) def outText(self,text):
self.textBrowser.append(text) class WorkerThread(QtCore.QThread):
sinOut = QtCore.pyqtSignal(str) def __init__(self,parent=None):
super(WorkerThread,self).__init__(parent) def setEvr(self,cssUrl,savePath):
self.cssUrl = cssUrl
self.savePath = savePath
self.start() def getMsg(self,msg):
self.sinOut.emit(msg) def run(self):
self.saveimg = saveCssBackImg(self.cssUrl,self.savePath)
self.saveimg.updateSig.connect(self.getMsg)
self.saveimg.saveImg() if __name__ == "__main__": app = QtGui.QApplication([])
ui = UI_getImg()
ui.setWindowFlags(QtCore.Qt.MSWindowsFixedSizeDialogHint)
ui.show()
app.exec_()
两处修复:
1.urllib.urlretrieve下载图片,对http status 404和403等也会保存成图片
python + pyqt 实现的你下载css背景图片的小工具(最终版)的更多相关文章
- CSS背景图片定位
原文:CSS背景图片定位 在网页开发中我们经常需要对图片进行分割(如下图)来使用,而不是分别提供单独的图片来调用,常见的如页面背景,按钮图标等,这样做的好处就是减少请求次数,节省时间和带宽. 对背景图 ...
- 利用wget 抓取 网站网页 包括css背景图片
利用wget 抓取 网站网页 包括css背景图片 wget是一款非常优秀的http/ftp下载工具,它功能强大,而且几乎所有的unix系统上都有.不过用它来dump比较现代的网站会有一个问题:不支持c ...
- Bootstrap css背景图片的设置
一. 网页中添加图片的方式有两种 一种是:通过<img>标签直接插入到html中 另一种是:通过css背景属性添加 居中方法:水平居中的text-align:center 和 margin ...
- css背景图片拉伸 以及100% 满屏显示
如何用css背景图片拉伸 以及100% 满屏显示呢?这个问题听起来似乎很简单.但是很遗憾的告诉大家.不是我们想的那么简单. 比如一个容器(body,div,span)中设定一个背景.这个背景的长宽值在 ...
- div css背景图片不显示
我们在写页面时,为了便于维护,css样式通常都是通过link外部导入html的,有时在css中写入背景图片时,此时背景图片的路径应该是相对css文件的.比如,此时的文件有index.html,css. ...
- 【IE6的疯狂之八】链接伪类(:hover)CSS背景图片有闪动BUG
IE6下链接伪类(:hover)CSS背景图片有闪动BUG,主要原因ie会再一次请求这张图片,或者说图片没被缓存. 例如: CSS代码 a:hover{background:url(imagepath ...
- 【转】链接伪类(:hover)CSS背景图片有闪动BUG
来源:http://www.css88.com/archives/744 --------------------------------------------------------------- ...
- 兼容各浏览器的css背景图片拉伸代码
需要用到背景图拉伸,找到了下面这段css代码: filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='***.jpg' , s ...
- css背景图片拉伸
css背景图片拉伸 background-image:url(bg.png); -moz-background-size: 100% 100%; -o-background-size: 100% 10 ...
- css背景图片位置:background的position(转)
css背景图片位置:background的position position的两个参数:水平方向的位置,垂直方向的位置----------该位置是指背景图片相对于前景对象的 1.backgroun ...
随机推荐
- 从一道CTF题学习python字节码到源码逆向
概述: 该题来源为2022爱春秋冬季赛ezpython,难度不是很大刚好适合我这样的萌新入门 题目: 3 0 LOAD_CONST 1 (204) 3 LOAD_CONST 2 (141) 6 LOA ...
- gin模板语法
输出数据: 语句:{{.}} 用法: 在html文件中调用 输出里面的结果 多个目录下定义模板: 语句:{{ define "xxx目录/xxx文件.html"}} ...
- 3、mysql着重号解决关键字冲突
1.着重号(` `): 使用着重号(` `)将字段名或表名括起来解决冲突:保证表中的字段.表名等没有和保留字.数据库系统名或常用方法名冲突
- [python]《Python编程快速上手:让繁琐工作自动化》学习笔记2
1. 读写文件笔记(第8章)(代码下载) 1.1 文件与文件路径 通过import os调用os模块操作目录,常用函数如下: 函数 用途 os.getcwd() 取得当前工作路径 os.chdir() ...
- [图像处理] YUV图像处理入门3
5 yuv420格式的灰阶测试图 本程序中的函数主要是为YUV420P视频数据流的第一帧图像添加边框.函数的代码如下所示: /** * @file 5 yuv_graybar.cpp * @autho ...
- Redis+Hbase+RocketMQ 实际使用问题案例分享
需求 将Hbase数据,解析后推送到RocketMQ. redis使用list数据类型,存储了需要推送的数据的RowKey及表名. 简单画个流程图就是: 分析及确定方案 Redis 明确list中元素 ...
- day09-AOP-02
AOP-02 4.问题提出 在上一篇的MyProxyProvider类中,我们的输出语句功能比较弱,在实际开发中,我们希望是以一个方法的形式,嵌入到真正执行的目标方法前,怎么办? 1.使用土方法解决 ...
- vue基础之keep-alvie保持历史页面数据不变,切换页面后数据不变keep-alvie
1:路由配置文件设置 { path: '/MenuM', component: Layout, redirect: '/MenuM', children: [ { path: 'MenuM', nam ...
- 迁移学习(ADDA)《Adversarial Discriminative Domain Adaptation》
论文信息 论文标题:Adversarial Discriminative Domain Adaptation论文作者:Eric Tzeng, Judy Hoffman, Kate Saenko, Tr ...
- ChatGPT:让程序开发更轻松
作者:京东科技 赵龙波 "贾维斯,你在吗?" "随时待命,先生." 类似<钢铁侠>里的人工智能助理贾维斯,ChatGPT或许是你的随时待命的助手.C ...