[经典] 使用Python批量重命名iPhone拍摄的照片-按照拍摄时间重命名
#!/usr/bin/env python
# -*- coding: utf-8 -*- '''
批量修改照片文件名称的Python脚本程序。
遍历指定目录(含子目录)的照片文件,根据拍照时间将照片文件名修改为以下格式:
20140315_091230.jpg (%Y%m%d_%H%M%S) 由于文件名已经精确到秒,理论上重名的概率非常小。
如果需要考虑到重名的问题,可以对本程序进行进一步的优化。 !该程序需要安装exifread模块,否则无法使用。
例如,Linux/Mac OS X下命令行安装该模块:sudo pip install exifread
''' import os
import stat
import time
import exifread
MY_DATE_FORMAT = '%Y%m%d_%H%M%S' SUFFIX_FILTER = [ '.jpg' , '.png' , '.mpg' , '.mp4' , '.thm' , '.bmp' , '.jpeg' , '.avi' , '.mov' ]
DELETE_FILES = [ 'thumbs.db' , 'sample.dat' ] def isFormatedFileName ( filename ) :
#判断是否已经是格式化过的文件名
try :
filename_nopath = os.path . basename ( filename )
f , e = os.path . splitext ( filename_nopath )
time . strptime ( f , MY_DATE_FORMAT )
return True
except ValueError :
return False def isTargetedFileType ( filename ) :
#根据文件扩展名,判断是否是需要处理的文件类型
filename_nopath = os.path . basename ( filename )
f , e = os.path . splitext ( filename_nopath )
if e . lower ( ) in SUFFIX_FILTER :
return True
else :
return False def isDeleteFile ( filename ) :
#判断是否是指定要删除的文件
filename_nopath = os.path . basename ( filename )
if filename_nopath . lower ( ) in DELETE_FILES :
return True
else :
return False def generateNewFileName ( filename ) :
#根据照片的拍照时间生成新的文件名(如果获取不到拍照时间,则使用文件的创建时间)
try :
if os.path . isfile ( filename ) :
fd = open ( filename , 'rb' )
else :
raise "[%s] is not a file!\n" % filename
except :
raise "unopen file[%s]\n" % filename data = exifread . process_file ( fd )
if data :
#取得照片的拍摄日期
try :
t = data [ 'EXIF DateTimeOriginal' ]
#转换成 yyyymmdd_hhmmss的格式
dateStr = str ( t ) . replace ( ":" , "" ) [ : 10 ] + "_" + str ( t ) [ 11 : ] . replace ( ":" , "" )
except :
pass #如果没有取得exif信息,则用图像文件的创建日期作为拍摄日期
state = os . stat ( filename )
dateStr = time . strftime ( MY_DATE_FORMAT , time . localtime ( state [ - 2 ] ) )
dirname = os.path . dirname ( filename )
filename_nopath = os.path . basename ( filename )
f , e = os.path . splitext ( filename_nopath )
newFileName = os.path . join ( dirname , dateStr + e ) . lower ( )
return newFileName def scandir ( startdir ) :
#遍历指定目录以及子目录,对满足条件的文件进行改名或删除处理
os . chdir ( startdir )
for obj in os . listdir ( os . curdir ) :
if os.path . isfile ( obj ) :
if isTargetedFileType ( obj ) and isFormatedFileName ( obj ) == False :
#对满足过滤条件的文件进行改名处理
newFileName = generateNewFileName ( obj )
print "rename [%s] => [%s]" % ( obj , newFileName )
os . rename ( obj , newFileName )
elif isDeleteFile ( obj ) :
#删除制定的文件
print "delete [%s]: " % obj
os . remove ( obj )
else :
pass
if os.path . isdir ( obj ) :
scandir ( obj )
os . chdir ( os . pardir ) if __name__ == "__main__" :
path = "/Users/abc/www/img"
scandir ( path )
[经典] 使用Python批量重命名iPhone拍摄的照片-按照拍摄时间重命名的更多相关文章
- Python批量复制和重命名文件
Python批量复制和重命名文件 示例代码 #! /usr/bin/env python # coding=utf-8 import os import shutil import time impo ...
- python批量进行文件修改操作
python批量修改文件扩展名 在网上下载了一些文件,因为某种原因,扩展名多了一个后缀'.xxx',手动修改的话因为文件太多,改起来费时费力,于是决定写个小脚本进行修改. 1.要点: import r ...
- python 批量创建文件及文件夹(文件夹里再创文件)
python 批量创建文件及文件夹(文件夹里再创文件)思路:文件建到哪>文件名字叫啥>创建文件夹>去新建的文件下>新建文件>给文件里边写东西>写个反馈给控制台> ...
- python批量导出项目依赖包及批量安装的方法
在Python中我们在项目中会用到各种库,自带的自然不必再说,然而如果是三方库,则在进行项目移植时通常需要在新的环境下安装需要的三方库文件,面对较大项目中众多的三方库,可以先将项目依赖库导出到txt文 ...
- 前向否定界定符 python正则表达式不匹配某个字符串 以及无捕获组和命名组(转)
[编辑] 无捕获组和命名组 精心设计的 REs 也许会用很多组,既可以捕获感兴趣的子串,又可以分组和结构化 RE 本身.在复杂的 REs 里,追踪组号变得困难.有两个功能可以对这个问题有所帮助.它们也 ...
- Python批量修改文本文件内容
Python批量替换文件内容,支持嵌套文件夹 import os path="./" for root,dirs,files in os.walk(path): for name ...
- python批量修改linux主机密码
+++++++++++++++++++++++++++++++++++++++++++标题:python批量修改Linux服务器密码时间:2019年2月24日内容:基于python实现批量修改linu ...
- 用python批量向数据库(MySQL)中导入数据
用python批量向数据库(MySQL)中导入数据 现有数十万条数据,如下的经过打乱处理过的数据进行导入 数据库内部的表格的数据格式如下与下面的表格结构相同 Current database: pyt ...
- python批量给云主机配置安全组
python批量给云主机配置安全组 用公有云的思路去思考去实现一个安全稳定.可伸缩和经济的业务构架,云运维是有别与传统运维的,比如说了解公有云的都知道安全组的概念,安全组跟防火墙功能很相似,那我的机器 ...
随机推荐
- 小白的Python之路 day5 hashlib模块
hashlib模块 一.概述 用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法 二.算法的演 ...
- Google免费GPU使用教程
今天突然看到一篇推文,里面讲解了如何薅资本主义羊毛,即如何免费使用Google免费提供的GPU使用权. 可以免费使用的方式就是通过Google Colab,全名Colaboratory.我们可以用它来 ...
- CCF系列之相邻数对(201409-1)
试题编号: 201409-1 时间限制: 1.0s 内存限制: 256.0MB 问题描述 给定n个不同的整数,问这些数中有多少对整数,它们的值正好相差1. 输入格式 输入的第一行包含一个整数n,表示给 ...
- 如何让你的.vue在sublime text 3 中变成彩色?
1.打开sublime,按住shift+Ctrl+P,回车 2.输入Vue Syntax Highlight(因为我的已经装过了,所以这里没有显示) 3.选择Vue Syntax Highlight, ...
- [转]另一种遍历Map的方式: Map.Entry 和 Map.entrySet()
转自: http://blog.csdn.net/mageshuai/article/details/3523116 今天看Think in java 的GUI这一章的时候,里面的TextArea这个 ...
- 流API--原始类型流
到目前为止,我们已经将整型收集到了一个Stream<Integer>的流中,不过将每个整数包装成相应对象显然是一个低效的做法,对于其他的基本类型也是一样,我们前面说过jdk提供包装类已经自 ...
- Redis清空数据
进入redis目录下 redis-cli -h IP -p 端口 -a 密码 flushall
- libev学习笔记
转 libev的使用--结合Socket编程 作者:cxy450019566 之前自己学过一些libev编程的基础,这次写压测刚好用上了,才算真正动手写了些东西,在这里做一些总结.写这篇文章是为了用浅 ...
- Python字符串详解
字符串 作用: 名字,性别,国籍,地址等描述信息 定义: 在单引号.双引号.三引号内,由一串字符组成 优先掌握的操作: 按索引取值(正向取+反向取):只能取 切片(顾头不顾尾,步长) 长度len 成员 ...
- malloc,calloc,realloc,alloc
三个函数的申明分别是: void* realloc(void* ptr, unsigned newsize); void* malloc(unsigned size); void* calloc(si ...