本文实例讲述了Python实现自动为照片添加日期并分类的方法。分享给大家供大家参考,具体如下:
小时候没怎么照相,所以跟别人说小时候特别帅他们都不信。小外甥女出生了,我给买了个照相机,让她多照相。可惜他舅目前还是个屌丝,买了个700的屌丝照相机,竟然没有自动加日期的功能。试了几个小软件,都不好用,大的图像软件咱又不会用。身为一个计算机科学与技术专业的学生,只能自立更生了。
听说Python有个图形库,不错,在照片上打日期很容易,于是我就下了这个库。对Python不熟,一面看着手册一面写的。完成了下面的小程序,很简单。还不实用,我再修改一下,加上图形界面,并且将Python代码转换成exe,因为我要把程序给我姐用,所以要做到最傻瓜式。
(1)在相片右下角打印日期,格式类似于 2012-12-05 10:23:46
(2)以上面的日期为例,将原文件重命名为20121205102346.jpg,生成的文件命名为20121205102346DATE.jpg,并且放入文件夹20121205中,这样就可以把相片自动分类了。两个相片拍摄时间到秒数就应该不同了,除非是连拍。
代码(事先安装PIL库,http://www.pythonware.com/products/pil/)
import os,sys,shutil from PIL import Image from PIL import ImageDraw from PIL.ExifTags import TAGS from PIL import ImageFont #open image file if len(sys.argv) < 2: print "Usage: ",sys.argv[0]," ImageFile" sys.exit(1) im = Image.open(sys.argv[1]) print 'Image size is:',im.size #get the info dict info = im._getexif() #info store the information of the image #it stores the info like this: [233:'name',2099:'2012:01:01 10:44:55',...] #the key need to be decoded, #This piece of code will extract the time when the photo is taken for tag,value in info.items(): decoded = TAGS.get(tag,tag) if decoded == 'DateTime': date = value break #The date time is in this format '2012:01:01 10:44:22', replace the first two ":" with "-", need a writable list date_list = [] for x in range(0,len(date)): date_list.append(date[x]) date_list[4] = '-' date_list[7] = '-' date = ''.join(date_list) #draw.text expect a string, convert it back to string #the font size will be 1/15 of the images size font = ImageFont.truetype("FZYTK.TTF",im.size[1] / 15) draw = ImageDraw.Draw(im) stringsize=draw.textsize(date,font=font) print 'Text size is:',stringsize #put the text to the right corner draw.text((im.size[0]-stringsize[0],im.size[1]-stringsize[1]),date,fill=255,font=font) #rename the source photo and the dated photo, eliminate the ':' and '-' and ' ' new_date_list = [] for x in range(0,len(date_list)): if date_list[x] != ':' and date_list[x] != '-' and date_list[x] != ' ': new_date_list.append(date_list[x]) date = ''.join(new_date_list[0:8]) time = ''.join(new_date_list[8:]) #print date #print time dir_name = ''.join(date) src_filename = ''.join(new_date_list) dst_filename = src_filename + 'DATE' #print dir_name #print src_filename #print dst_filename if not os.path.isdir(dir_name): os.makedirs(dir_name) path = dir_name + '/' + dst_filename +'.JPG' #print path im.save(path) shutil.copy(sys.argv[1],dir_name+'/'+src_filename+'.JPG')
效果图如下:
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]