不知道大家有没有这样的体验,windows电脑上查看一张gif图,默认就把IE给打开了,还弹出个什么询问项,好麻烦的感觉。所以为了解决自己的这个问题,写了个简单的文件夹内图片浏览工具。
效果图
以E盘某一文件夹为例
效果图
实现思路
业务代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
# coding:utf-8 import sys reload (sys) sys.setdefaultencoding( 'utf8' ) # __author__ = '郭 璞' # __date__ = '2016/8/5' # __Desc__ = 自动生成网页相册 import os # 呵呵了,原来有标准库中的walk方法。那么这个方法就获得一个文件夹下的图片文件吧 def getFiles(filepath): files = [] if os.path.isdir(filepath): for file in os.listdir(filepath): if os.path.isdir( file ): getFiles( file ) elif file .endswith( '.jpg' ) or file .endswith( '.png' ) or file .endswith( '.gif' ): files.append(filepath + str ( file )) elif os.path.isfile(filepath): files.append(filepath) return files # 获取给定目录下所有以.jpg .png .gif结尾的文件,并补全路径保存到列表中输出 def recourse(filepath): files = [] for fpathe, dirs, fs in os.walk(filepath): for f in fs: if f.endswith( '.jpg' ) or f.endswith( '.png' ) or f.endswith( '.gif' ): files.append(os.path.join(fpathe, f)) return files # 生成网页源码文件,指定 def generate(files, shuffle = False ): template_start = ''' <html><head><meta charset='utf-8'><title>网页版相册</title><link rel="stylesheet" type="text/css" href="csshake-slow.min.css"> <link rel="stylesheet" type="text/css" href="http://csshake.surge.sh/csshake-slow.min.css"></script></head><body> ''' template_body = '' # 如果指定乱序,就乱序列表中的数据 if shuffle = = True : from random import shuffle shuffle(files) for file in files: template_body + = '<a href="' + file + '"><img class="shake-slow" src="' + file + '" style="width:64px;height:auto;"></a>' template_end = ''' </body></html> ''' % html = template_start + template_body + template_end return html # 生成html文件,并输出到指定的目录 def write2File(filepath, data): file = open (filepath, 'wb' ) file .write(data) file .close() print 'Write to file Scuuess!' if __name__ = = "__main__" : # E:\\Picture\\LOFTER\\ filepath = 'E:\\Picture\\LOFTER\\' files = recourse(filepath = filepath) for item in files: print item html = generate(files, True ) output_path = r 'C:\Users\Administrator\Desktop\test.html' write2File(filepath = output_path, data = html) print 'HTML相册文件已生成在桌面,请查看' |
总结
•首先说一下缺点:
◦缺点很明显,对于中文支持的不够好,因为查看图片大图的时候是以超链接的形式出现的,所以会发生乱码的情况。
◦然后是优点:
优点不是很明显,因为如果一个文件夹下面有很多的子文件夹,或者图片很多的时候,就会很慢了。
•然后说一下可以改进的地方
◦引入JQuery,添加双击事件相应,实现双击删除不想要的图片
◦使用多线程的方式运行代码,加快网页的生成速度
最后,我想说的是,虽然这是个娱乐性质的小东西,但是多发挥一下想象力,不断地完善,对我们开发而言,一定会有帮助的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/marksinoberg/article/details/52131417