您的位置:首页 > 编程语言 > Python开发

批量删除含特殊符号的前缀/后缀文件名——python实现

2019-03-19 17:59 1261 查看
版权声明:转载附加出处链接 https://blog.csdn.net/weixin_39975436/article/details/88668728

对于上节增加前缀内容时,用了个mark变量将输入的前缀名用“[]”括起来了,当需要批量删除“[]”及其中内容时,可以使用正则表达式相关函数。正则表达式(re模块),是一个特殊的字符序列,它能帮助用户方便的检查一个字符串是否与某种模式匹配。例如本文用到了re.match()函数,该函数的功能是从字符串的起始位置匹配一个模式,如果非起始位置匹配成功,则match()函数就会返回空(none):通常match()函数的语法格式为:
re.match(pattern,string,flags=0)
其中,参数pattern 表示的是匹配的正则表达式,也可以理解为匹配模版;参数string 表示的是待匹配的字符串;参数flags 表示的是匹配标志位,用于控制正则表达式的匹配方式,比如是否区分大小写、多行匹配等。
对于匹配成功的字符串,正则表达式会将原输入内容分成几个区域,例如对于下图所示的文件名类型,我们可以将其分为两个区域(“group(1)和group(2)”):[test]和xxx.tiff.

本文删除特定字符“[]”及内部内容用到的思路是:先遍历所有文件名,利用正则表达式找到文件名中含有特殊字符“[]”的位置,然后利用os中的rename函数重新命名不含这些特殊字符的文件名。所以程序如下:

import os,re,sys

def remove_add(path):
os.chdir(path)
filelist = os.listdir(path)
for filename in filelist:
try:
result = re.match(r"(^\[.*\])(.*)",filename).group(2)

if result:
os.rename(filename,result)
except Exception as e:
pass#这里加了个异常检测,如果异常就pass

remove_add("/home/zhangqi/anhui1")
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: