(python)递归地从目录结构中删除大写?

问题描述 投票:0回答:2

大写字母 - 它们有什么意义?他们给你的只是RSI。

我想从我的目录结构中删除尽可能多的大写字母。我该如何编写一个脚本来用 python 来执行此操作?

它应该递归地解析指定的目录,识别大写字母的文件/文件夹名称,并以小写字母重命名它们。

python uppercase
2个回答
16
投票

os.walk
非常适合使用文件系统进行递归操作。

import os


def lowercase_rename(folder):
    # renames all subforders of folder, not including folder itself
    def rename_all(root, items):
        for name in items:
            try:
                os.rename(os.path.join(root, name), os.path.join(root, name.lower()))
            except OSError:
                pass  # can't rename it, so what

    # starts from the bottom so paths further up remain valid after renaming
    for root, dirs, files in os.walk(folder, topdown=False):
        rename_all(root, dirs)
        rename_all(root, files)

向上遍历树的要点是,当您有像“/A/B”这样的目录结构时,您在递归期间也会有路径“/A”。现在,如果从顶部开始,您将首先将 /A 重命名为 /a,从而使 /A/B 路径无效。另一方面,当您从底部开始并先将 /A/B 重命名为 /A/b 时,它不会影响任何其他路径。

实际上,您也可以使用

os.walk
进行自顶向下,但这(稍微)更复杂。


2
投票

尝试以下脚本:

#!/usr/bin/python

'''
renames files or folders, changing all uppercase characters to lowercase.
directories will be parsed recursively.

usage: ./changecase.py file|directory
'''

import sys, os

def rename_recursive(srcpath):
    srcpath = os.path.normpath(srcpath)
    if os.path.isdir(srcpath):
        # lower the case of this directory
        newpath = name_to_lowercase(srcpath)
        # recurse to the contents
        for entry in os.listdir(newpath): #FIXME newpath
            nextpath = os.path.join(newpath, entry)
            rename_recursive(nextpath)
    elif os.path.isfile(srcpath): # base case
        name_to_lowercase(srcpath)
    else: # error
        print "bad arg: " + srcpath
        sys.exit()

def name_to_lowercase(srcpath):
    srcdir, srcname = os.path.split(srcpath)
    newname = srcname.lower()
    if newname == srcname:
        return srcpath
    newpath = os.path.join(srcdir, newname)
    print "rename " + srcpath + " to " + newpath
    os.rename(srcpath, newpath)
    return newpath

arg = sys.argv[1]
arg = os.path.expanduser(arg)
rename_recursive(arg)
© www.soinside.com 2019 - 2024. All rights reserved.