说明,本人对象负责的项目有大量的加工图像,分别有A2 A3 A4 等规格,且这些图像都是在一起存储,按照相关的档案顺序全组;现在让我分别统计一共的图像数量 以及A2 A3 A4数量,经过一晚努力,现将代码公布如下:
这里主要用到了Image这个模块,需要自行下载
路径注意事项:在Windows里,需要将路径中的\全部改成//
适用场景:有大量图像,需要区分出A3 A4 对应的数量
实现手段:遍历目录,并打开文件比较其像素大小值
功能的实现:除了按照像素值比较图像大小区分外,
额外功能的增加:1加入了只针对.jpg图像进行处理,即使用其它格式的文件也不会影响程序执行;
2加入了异常处理,即文件是图像,但是无法打开,这块会定义它为错误图像;这里利用了try,即程序不会因为图像打不开而中断
实现语言:python
样例:
#!/usr/bin/env python
import os
import os.path
import Image
A1=0
A2=0
A3=0
A4=0
total = 0
errornum = 0
rootdir = "F://数据备份"
errorfile = 'd://图像错误.txt'
for parent,dirnames,filenames in os.walk(rootdir):
if len(filenames) > 0 and len(dirnames) == 0:
for i in range(len(filenames)):
filename = parent + "//" + filenames[i]
if filename.find(".jpg") > 0:
total+=1
print filename
try:
p_w_picpath = Image.open(filename)
except :
errornum = errornum + 1
error = file(errorfile,'a')
error.write('\r\n')
error.write(filename)
error.flush
continue
p_w_picpath_size = p_w_picpath.size[0]
if p_w_picpath_size <= 3500:
A4 = A4 + 1
elif p_w_picpath_size > 3500 and p_w_picpath_size <= 6000:
A3 = A3 + 1
elif p_w_picpath_size > 6000 and p_w_picpath_size <= 9000:
A2 = A2 + 1
elif p_w_picpath_size > 9000:
A1 = A1 + 1
else:
continue
print "-------------------------------------------------"
print "总数如下:%d\r"% total
print "A1一共有:%d\r"% A1
print "A2一共有:%d\r"% A2
print "A3一共有:%d\r"% A3
print "A4一共有:%d\r"% A4
print '错误图像有共有:%d\r'% errornum