基于Python处理Windows的文件名校验、非法字符过滤
当需要保存文件且用户自定义文件名称时,需要对文件名称进行合法性校验。
校验的内容包括:1. 是否包含非法字符;2. 是否超过最大长度;3. 是否符合Windows文件名称规范;4.批量生成保存同一格式的文件时,名称不能重复,否则会覆盖。
方法一:替换
def clean_filename(filename):
# 替换非法字符为下划线
filename = re.sub(r'[\\/:"*?<>|]', '', filename)
# 移除文件名开头的点和空格
filename = filename.lstrip('. ')
# 截断文件名以满足长度限制
filename = filename[:255]
return filename
若批量生成文件,可以对多个文件的文件名加上index序号索引,防止文件名重复:
name = "用户输入的自定义文件名"
for index in range(file_count):
filename = f"{index+1}_{name}.{file_extension}" # file_extension是文件扩展名,又称格式
filename = clean_filename(filename)
file_save_path = f"{folder_path}/{filename}" # folder_path是文件需要保存的文件夹路径
# 执行保存文件操作
方法二:转换
windows中,非法文件字符有以下:\/:*?"<>|
对应的合法全角字符为:\/:*?"<>|
def clean_filename2(filename):
reg = str.maketrans('\/:*?"<>|', '\/:*?"<>|')
return filename.translate(reg)
THE END
0
二维码
打赏
海报
基于Python处理Windows的文件名校验、非法字符过滤
当需要保存文件且用户自定义文件名称时,需要对文件名称进行合法性校验。
校验的内容包括:1. 是否包含非法字符;2. 是否超过最大长度;3. 是否符合Windows文……
共有 0 条评论