aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2023-11-13 13:46:34 +0800
committercrupest <crupest@outlook.com>2023-11-13 13:47:29 +0800
commitae2797f39d95a4c24c2adb6465cb947e4b5e28ed (patch)
treed4abce5de5ceb563ecdb3f7d6aa51168dcd24743
parentb3a15352c7019c9b6b9a790aba55e71454e4a2fa (diff)
downloadcrupest-ae2797f39d95a4c24c2adb6465cb947e4b5e28ed.tar.gz
crupest-ae2797f39d95a4c24c2adb6465cb947e4b5e28ed.tar.bz2
crupest-ae2797f39d95a4c24c2adb6465cb947e4b5e28ed.zip
(tools) add rename-tree.py
-rwxr-xr-xtools/rename-tree.py37
1 files changed, 37 insertions, 0 deletions
diff --git a/tools/rename-tree.py b/tools/rename-tree.py
new file mode 100755
index 0000000..c177eb6
--- /dev/null
+++ b/tools/rename-tree.py
@@ -0,0 +1,37 @@
+#!/usr/bin/env python3
+
+import argparse
+import os
+import os.path
+import re
+
+parser = argparse.ArgumentParser(
+ prog='rename-tree',
+ description='Recursively rename directories and files')
+
+parser.add_argument('old')
+parser.add_argument('new')
+parser.add_argument('dirs', nargs="+")
+
+args = parser.parse_args()
+
+old_regex = re.compile(args.old)
+new = args.new
+
+def rename(path, isdir):
+ dirname = os.path.dirname(path)
+ filename = os.path.basename(path)
+ new_filename = re.sub(old_regex, new, filename)
+ dir_str = "/" if isdir else ""
+ if new_filename != filename:
+ os.rename(path, os.path.join(dirname, new_filename))
+ print(f"{path}{dir_str} -> {new_filename}{dir_str}")
+
+for i, d in enumerate(args.dirs):
+ print(f"[{i + 1}/{len(args.dirs)}] Run for {d}:")
+ for dirpath, dirnames, filenames in os.walk(d, topdown=False):
+ for filename in filenames:
+ rename(os.path.join(dirpath, filename), False)
+ rename(dirpath, True)
+
+print("Done!")