开发的第一步,首先得熟悉脚本中使用的模块函数,废话不多说,开干!

1 函数介绍

1.1 os 模块

(1)os.lisdir()

>>> import os
>>> print(os.listdir())
['.env', 'rename.py', '.rename.py.swp']

此函数的作用即列出指定目录下的所有文件与目录的名,并以列表形式展现。

(2)os.path.splitext()

>>> import os
>>> print(os.path.splitext('rename.py'))
('rename', '.py')

在函数中指定一个文件名,用于分割文件名与后缀,结果存储于元组中

(3)os.path.join()

>>> import os
>>> print(os.path.join('/etc','nginx','nginx.conf'))
/etc/nginx/nginx.conf

将函数中的目录、文件组合成一个路径

(4)os.rename()

>>> import os
>>> os.rename('src','dest') # src 为原文件名,dest 为目标文件名

将目录或文件重命名

1.2 argparse 模块

​ Python 中内置模块,用于解析给出的函数参数,生成有用信息。

# argparse 模块示例源码
[root@localhost Python]# cat test.py
import argparse parser = argparse.ArgumentParser(description='Process some integers.')
parser.add_argument('integers', metavar='N', type=int, nargs='+',
help='an integer for the accumulator')
parser.add_argument('--sum', dest='accumulate', action='store_const',
const=sum, default=max,
help='sum the integers (default: find the max)') args = parser.parse_args()
print(args.accumulate(args.integers))
print(args.integers) # 使用示例
[root@localhost Python]# python test.py -h
usage: test.py [-h] [--sum] N [N ...] Process some integers. positional arguments:
N an integer for the accumulator optional arguments:
-h, --help show this help message and exit
--sum sum the integers (default: find the max) [root@localhost Python]# python test.py 123 45 8 --sum
176 # 求和后的值
[123, 45, 8]
[root@localhost Python]# python test.py 123 45 8
123 # 未添加 sum 参数,默认显示参数中最大值,对应 add_argument 的 default=max
[123, 45, 8] # 示例摘自链接:https://wiki.jikexueyuan.com/project/explore-python/Standard-Modules/argparse.html

​ argparse 模块的使用分为四步走,模块导入 -> ArgumentParser 创建对象 -> add_argument 添加参数 -> parse_args 调用

add_argument 函数中部分参数含义:

metavar		# 在 usage 中显示的参数名称
type # 接收到的参数,需转换成的目标类型
nargs # 表示参数个数,上例使用 +,代表有1个或多个参数
help # usage 中显示的参数帮助信息
dest # 可用此参数重定义的值访问参数(args.accumulate(args.integers)),基于上面示例

2 脚本文件

import argparse,os

# 解析参数,并生成 usage 提示,-h 显示帮助
def parse():
parser = argparse.ArgumentParser(description='批量修改文件名')
parser.add_argument('target_dir', metavar='TARGET_DIR', type=str, nargs=1, help='需批量修改文件所在目录')
parser.add_argument('old_ext', metavar='OLD_EXT', type=str, nargs=1, help='旧文件后缀')
parser.add_argument('new_ext', metavar='NEW_EXT', type=str, nargs=1, help='新文件后缀')
return parser def filename_modify(target_dir,old_ext,new_ext):
for filename in os.listdir(target_dir):
file = os.path.splitext(filename) # 将文件名与后缀分割开
file_ext = file[1] # 获得旧后缀 if old_ext == file_ext: # 查看此目录中是否有需修改的旧后缀文件
newname = file[0] + new_ext # 文件或目录重命名
os.rename(
os.path.join(target_dir, filename),
os.path.join(target_dir, newname)
) def main():
parser = parse()
args = vars(parser.parse_args())
work_dir = args['target_dir'][0]
old_ext = args['old_ext'][0]
new_ext = args['new_ext'][0] if old_ext[0] != '.':
old_ext = '.' + old_ext
if new_ext[0] != '.':
new_ext = '.' + new_ext filename_modify(work_dir,old_ext,new_ext) if __name__ == '__main__':
main()

main 函数中,args的值类似如下内容

python rename.py /root/Test txt py
{'work_dir': ['/root/Test'], 'old_ext': ['txt'], 'new_ext': ['py']}

因此,在 main 中,第一个索引 0 取的值为运行的命令行参数(列表),第二个索引值 0 用于判断带参数运行的文件后缀参数是否带有点

代码参考源地址

——————————————————————— END ———————————————————————

利用 Python 批量修改文件名的更多相关文章

  1. 利用python批量修改word文件名的方法示例

    利用python批量修改word文件名的方法示例 最近不小心把硬盘给格式化了,由于当时的文件没有备份,所以一下所有的文件都没有了,于是只能采取补救措施,用文件恢复软件恢复了一部分的数据出来,但是恢复完 ...

  2. python:批量修改文件名批量修改图片尺寸

    批量修改文件名  参考博客:https://www.cnblogs.com/zf-blog/p/7880126.html 功能:批量修改文件名 1 2 3 4 5 6 7 8 9 10 11 12 1 ...

  3. 用python批量修改文件名

    从youtube上当下来百来首mv,每个都需要去掉视频,这还挺好弄得,格式工厂一弄就完了,但是文件名,都带有乱七八糟的*啥的巴拉巴拉的,咋修改啊,几百首总不可能一个一个rename吧 #批量修改文件名 ...

  4. ML二:python批量修改文件名-测试KDTree

    (1):#批量修改文件名 import os import numpy as np import string import shutil prefix =''#单引号,前缀! sufix ='txt ...

  5. Python批量修改文件名-后缀

    LyncLynn用途: 批量修改文件格式,文件名后缀. #Version: V1.0 #Author:lynclynn #Description:Change the filename #Create ...

  6. Python 批量修改文件名

    最近下载了几部美剧(越狱.迷失.权利的游戏......),每集文件名都好长好长..想改短一些,但一个一个改太累了,于是写了个脚本来实现批量修改: 修改前文件名: 修改后文件名: 代码实现: #enco ...

  7. Python批量修改文件名(os库)

    问题: 在某一文件夹内有97个sql文件,全部都以统一格式命名,例如“A201222-广州李小龙纪念协会-1-广州李小龙纪念协会-2018.AUD” 由于有两段重复了,而且中间的“1”也没有意义,需要 ...

  8. 视频合并时使用python批量修改文件名

    不知道大家有没有遇到这样的情况,比如视频合并时文件名没有按照正常顺序排列,像这样 可见,文件名排序是乱的.这个样子合并出来的视频一定也是乱的.所以得想办法把文件名修改一下,让软件读取出正确的顺序.闲话 ...

  9. Python批量修改文件名与后缀

    引言: 有时因为文件版本的更新,后缀名会发生变化,例如Word13的docx到Word16的doc,又例如我们想修改音频文件的后缀.一个一个修改后缀名往往很麻烦,于是我们便可以写一个Python的脚本 ...

随机推荐

  1. PyCharm创建文件时自动添加头文件

    依次找到以下路径: File->settings->Editor->File and Code Templates->Python Script  #!/usr/bin/env ...

  2. python-----opencv读视频、循环读图片显示进度条

    功能:opencv读视频,显示进度条,推动进度条快进.后退,按q退出.代码如下: import os import cv2 def nothing(emp): pass def jindu(name, ...

  3. 洛谷P1531 I Hate It

    题目背景 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感. 题目描述 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的 ...

  4. MSD6A628开发资料与技术支持

    MSD6A628VX/VXM是mstar推出的低成本安卓智能网络电视方案,628分两个版本,一个是内置512MB内存,一个是外挂1G内存, 安卓4.4系统,4核A7处理器,Mali450MP2 GPU ...

  5. Spark GraphX 聚合操作

    package Spark_GraphX import org.apache.spark.{SparkConf, SparkContext} import org.apache.spark.graph ...

  6. PCB Genesis拼SET画工艺边 实现方法(一)

    在PCB行业中,客户提供的PCB尺寸较小,为方便PCB加工,并生产提高生产效率,通常小于80X80mm需拼板处理的, 拼板要求可能来自按户指定拼板,也有可能是由工厂自行拼板,但对于CAM来说就需将PC ...

  7. vue中父组件传数据给子组件

    父组件: <template> <parent> <child :list="list"></child> //在这里绑定list对 ...

  8. bzoj 1045: [HAOI2008] 糖果传递【瞎搞】

    感觉我的智商可能不够写题解,就直接截了hzwer的blog 地址http://hzwer.com/2656.html #include<iostream> #include<cstd ...

  9. eccharts-gl 3D立体柱状图

    echarts-gl继承于echarts echarts-gl官方实例https://echarts.baidu.com/examples/index.html#chart-type-globe 代码 ...

  10. mycat登录报错Host 'XXX' is blocked because of many connection errors的另一种解决思路

    报错时机 使用了mycat,而不是单纯使用了mysql. 报错信息 ERROR 1129 (HY000): Host '1.23.22.18' is blocked because of many c ...