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 ...
随机推荐
- 线性构造treap
数据结构 线性构造treap treap的线性构造可以使复杂度锐减到\(O(n)\),很优秀 treap的本质就是小根堆+二叉搜索树,即保证val满足搜索树的同时,维护rad的小根堆. 现在我们先把数 ...
- lock 和 Monitor (转载)
Lock和Monitor都是对被操作对象同步控制的方法 Lock 是 Monitor的简化版本,IL callvirt ...Monitor.Enter(object)...leave.s.... c ...
- (18)go-micro微服务ELK介绍
目录 一 什么是ELK 二 Beats的六种工具 三 ELK系统的特点 四 ELK+beats系统架构 五 ELK优点 六 最后 一 什么是ELK ELK是三个[开源软件]的缩写,分别表示:Elast ...
- 如何在 pyqt 中使用动画实现平滑滚动的 QScrollArea
前言 在之前的博客<如何在 pyqt 中实现平滑滚动的 QScrollArea>中,我们使用定时器和队列实现了平滑滚动.但是实现代码还是有一点复杂,所以这篇博客将使用 Qt 的动画框架 Q ...
- djiango框架推导过程,jinja2模板语法,jiango简介,基本操作命令
djiango框架推导过程,jinja2模板语法,jiango简介,基本操作命令 一.web框架前戏 web 框架可以理解为是基于会联网的web服务端>>>socket服务端 1.w ...
- 包子类&包子铺类-吃货类&测试类
包子类&包子铺类 资源类:包子类设置包子的属性皮陷包子的状态:有true,没有false package Demo01.WaitAndNotify; /** * 资源类:包子类设置包子的属性 ...
- 计算机重装Windows操作系统
这里使用虚拟机模拟电脑安装操作系统: 一.安装ventoy U盘启动工具: 注意:1.这一步需要格式化U盘,所以最好使用空U盘或者提前备份. 2.这里是下载在电脑上面,不是下载在U盘里面. 下载好后进 ...
- DevGridView表格导出自定义页脚
在CustomSummaryCalculate 事件里 //强制初始化,如果列是动态通过数据源加载的,则绑定数据源后gridview想获取列的话,需要调用强制初始化的方法 view.GridContr ...
- day05-SpringMVC底层机制简单实现-01
SpringMVC底层机制简单实现-01 主要完成:核心分发控制器+Controller和Service注入容器+对象自动装配+控制器方法获取参数+视图解析+返回JSON格式数据 1.搭建开发环境 创 ...
- linux 基础(7)账号和群组的管理
了解账号和群组的基本信息 账号使用 如何查看 linux 计算机上有哪些账号呢?账号的信息储存在/etc/passwd中,打开就可以看到: less /etc/passwd root:x:0:0:ro ...