code2md/run_img2markdown.command
| #! /bin/bash |
| |
| source /Users/song/Code/script_python/code2md/venv/bin/activate |
| |
| |
| |
| |
| python3 /Users/song/Code/script_python/code2md/main_img2markdown.py |
| |
| |
| |
| |
| |
code2md/main_img2markdown.py
| import os |
| import re |
| import sys |
| import time |
| import easygui |
| from easygui import * |
| |
| |
| from urllib.parse import quote |
| |
| class User(EgStore): |
| def __init__(self, filename): |
| self.path = '' |
| EgStore.__init__(self, filename) |
| |
| |
| def get_dir_path_gui(): |
| |
| user = User("settings.txt") |
| |
| user.restore() |
| file_path = easygui.diropenbox(default=user.path) |
| user.path = file_path |
| user.store() |
| return file_path |
| |
| |
| def date_to_timestamp(date, format_string="%Y-%m-%d %H:%M:%S"): |
| time_array = time.strptime(date, format_string) |
| time_stamp = int(time.mktime(time_array)) |
| return time_stamp |
| |
| |
| def sort_files(file_path): |
| return sorted(file_path,key=lambda name:date_to_timestamp(name[2:-4],format_string="%Y-%m-%d %H.%M.%S")) |
| |
| |
| |
| def get_images(path): |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| for file in files: |
| |
| res_abort = re.findall(re.compile( |
| r'( \(2\)\.png)$'), file) |
| if res_abort: |
| continue |
| res_save = re.findall(re.compile(r'(\.png|jpg)$'), file) |
| if len(res_save): |
| |
| file_path.append(file) |
| |
| return file_path |
| |
| |
| def write2md(index,img_path, root_path): |
| with open(root_path + '/NOTE.md', "a", encoding='utf-8') as f: |
| f.write(f"# {index}\n\n") |
| f.write(f"data:image/s3,"s3://crabby-images/31f84/31f842297f766cd15b4408ae86e1229f81b4194a" alt="img"") |
| f.write(f"\n\n\n") |
| |
| |
| if __name__ == '__main__': |
| |
| dir_name = get_dir_path_gui() |
| |
| |
| md_file = os.path.join(dir_name, '====NOTE.md') |
| |
| if os.path.exists(md_file): |
| os.remove(md_file) |
| |
| img_path_list = get_images(dir_name) |
| sorted_img_path_list = sort_files(img_path_list) |
| parsed_sorted_img_path_list = list(map(lambda file: quote('./'+file), sorted_img_path_list)) |
| |
| for index,img_path in enumerate(parsed_sorted_img_path_list): |
| write2md(index,img_path, dir_name) |
| print('!!!complete!!!') |
| os.system('open '+dir_name) |
| |
code2md/code2md_多级标题.py
| |
| import os |
| import subprocess |
| import re |
| import shutil |
| import sys |
| from pathlib import Path |
| from datetime import datetime |
| |
| |
| |
| def get_root_dir(dir_path): |
| file_list = os.listdir(dir_path) |
| path_list = [] |
| root_file_list = [] |
| for file in file_list: |
| print(file) |
| |
| if file.startswith('.'): |
| continue |
| |
| is_file = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file) |
| if len(is_file): |
| |
| res_abort = re.findall(re.compile( |
| r'(d\.ts|config\.ts|-lock\.json)$'), file) |
| if res_abort: |
| continue |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|config\.js|js|ts|html|txt|go|mod|json)$'), file) |
| if len(res_save): |
| root_file_list.append(file) |
| continue |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE)'), file) |
| if len(res_abort): |
| continue |
| |
| file_path = os.path.join(dir_path, file) |
| path_list.append(file_path) |
| return path_list, root_file_list |
| |
| |
| def get_deep_dirs(path): |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| del_dir_index = [] |
| for i, dir in enumerate(dirs): |
| |
| if dir.startswith('.'): |
| del_dir_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE|assets|vendor|tmp|static|templates)'), dir) |
| if len(res_abort): |
| del_dir_index.append(i) |
| |
| |
| del_dir_index = list(set(del_dir_index)) |
| del_dir_index.sort() |
| for counter, index in enumerate(del_dir_index): |
| index = index - counter |
| dirs.pop(index) |
| |
| |
| del_file_index = [] |
| for i, file in enumerate(files): |
| |
| |
| if file.startswith('.'): |
| del_file_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(_NOTE\.md|\.d\.ts|\.lock|\.png|\.woff2|\.ttf|\.woff|\.css|README\.md|\.toml|swagger-ui-bundle.js|-lock\.json)$'), |
| file) |
| if len(res_abort): |
| del_file_index.append(i) |
| |
| |
| del_file_index = list(set(del_file_index)) |
| del_file_index.sort() |
| for counter, index in enumerate(del_file_index): |
| index = index - counter |
| files.pop(index) |
| |
| |
| for file in files: |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|js|ts|html|go|mod|json)$'), file) |
| if len(res_save): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| |
| def readcode_writemd(file_path,root_path ,md_file_path): |
| suffix = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file_path) |
| if len(suffix): |
| suffix = suffix[0][1:] |
| with open(file_path, "r", encoding='utf-8') as f: |
| rest_line = f.read() |
| write2md(rest_line,suffix, file_path, root_path,md_file_path) |
| |
| |
| |
| def get_md_title_path(file_path,root_path): |
| |
| common_prefix = os.path.commonprefix([file_path, root_path]) |
| |
| diff1 = file_path[len(common_prefix)+1:] |
| |
| |
| |
| md_title = os.path.join(os.path.basename(root_path),diff1) |
| return md_title |
| |
| |
| |
| def write2md(content, suffix, file_path,root_path, md_file_path): |
| with open(md_file_path, "a", encoding='utf-8') as f: |
| md_title = get_md_title_path(file_path,root_path) |
| f.write(f"# `{md_title}`\n\n") |
| f.write(f"```{suffix}\n") |
| f.write(content) |
| f.write(f"\n") |
| f.write(f"```\n\n\n") |
| |
| |
| |
| def get_root_path(path): |
| dir_path = path |
| |
| if os.path.isfile(path): |
| dir_path = os.path.dirname(path) |
| return dir_path |
| |
| |
| |
| def get_file_name(): |
| |
| now = datetime.now() |
| |
| time_str = now.strftime('%Y-%m-%d_%H-%M-%S') |
| |
| file_name = f'Z_{time_str}_NOTE.md' |
| return file_name |
| |
| |
| |
| |
| if __name__ == '__main__': |
| input_list = sys.argv[1].split(' ') |
| input_file_path = input_list[0] |
| |
| md_lv_one = os.path.basename(input_file_path) |
| |
| if len(input_list) > 1: |
| |
| input_list = input_list[1:] |
| |
| output_list = [x for x in input_list if x] |
| md_lv_one = output_list[0] |
| |
| |
| |
| root_path = get_root_path(input_file_path) |
| md_file_name = get_file_name() |
| md_file_path = os.path.join(root_path, md_file_name) |
| file_path_list = get_deep_dirs(root_path) |
| |
| |
| |
| for i,file_path in enumerate(file_path_list): |
| print(i,'->',get_md_title_path(file_path,root_path)) |
| readcode_writemd(file_path, root_path,md_file_path) |
| |
| print('=============done=============') |
| |
| |
| |
code2md/run_code2md.command
| #! /bin/bash |
| |
| |
| echo "请拖入一个代码项目根目录的文件或者文件夹:" |
| read file |
| python3 /Users/song/Code/script_python/code2md/code2md.py "$file" |
| |
| sleep 3 |
| osascript -e 'tell application "Terminal" to close first window' & exit |
| |
| |
| |
| |
code2md/test.py
| import time |
| |
| names = ["截屏2023-03-12 14.46.00.png", |
| "截屏2023-03-12 14.38.50.png", |
| "截屏2023-03-12 14.48.17.png", |
| "截屏2023-03-12 14.47.26.png", |
| "截屏2023-03-12 14.35.46.png", |
| "截屏2023-03-12 14.40.34.png", |
| "截屏2023-03-12 14.23.45.png", |
| "截屏2023-03-12 14.41.10.png"] |
| |
| |
| |
| def date_to_timestamp(date, format_string="%Y-%m-%d %H:%M:%S"): |
| time_array = time.strptime(date, format_string) |
| time_stamp = int(time.mktime(time_array)) |
| return time_stamp |
| |
| |
| names.sort(key=lambda name:date_to_timestamp(name[2:-4],format_string="%Y-%m-%d %H.%M.%S")) |
| |
| for name in names: |
| print(name) |
| |
| |
code2md/check_alias.sh
| #!/bin/bash |
| read -p "Enter file path: " file_path |
| is_alias=$(GetFileInfo -aa "$file_path") |
| if [ "$is_alias" == "1" ]; then |
| echo "yes" |
| else |
| echo "no" |
| fi |
| |
code2md/code2md.py
| |
| import os |
| import subprocess |
| import re |
| import shutil |
| import sys |
| from pathlib import Path |
| from datetime import datetime |
| |
| |
| exclude_dirs = ['__pycache__', 'venv', 'build', 'dist', 'node_modules', 'public', 'LICENSE', 'assets', 'vendor', 'tmp', 'static', 'templates'] |
| |
| exclude_files = ['_NOTE.md', '.d.ts', '.lock', '.png', '.woff2', '.ttf', '.woff', '.css', 'README.md', '.toml', 'swagger-ui-bundle.js', '-lock.json'] |
| |
| include_exts = ['.py', '.vue', '.js', '.ts', '.html', '.go', '.mod', '.json','.txt','.sh','.command'] |
| |
| md_suffix_table = { |
| 'command': 'sh', |
| } |
| |
| |
| def get_root_dir(dir_path): |
| file_list = os.listdir(dir_path) |
| path_list = [] |
| root_file_list = [] |
| for file in file_list: |
| print(file) |
| |
| if file.startswith('.'): |
| continue |
| |
| is_file = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file) |
| if len(is_file): |
| |
| res_abort = re.findall(re.compile( |
| r'(d\.ts|config\.ts|-lock\.json)$'), file) |
| if res_abort: |
| continue |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|config\.js|js|ts|html|txt|go|mod|json)$'), file) |
| if len(res_save): |
| root_file_list.append(file) |
| continue |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE)'), file) |
| if len(res_abort): |
| continue |
| |
| file_path = os.path.join(dir_path, file) |
| path_list.append(file_path) |
| return path_list, root_file_list |
| |
| |
| def get_deep_dirs(path): |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| del_dir_index = [] |
| for i, dir in enumerate(dirs): |
| |
| if dir.startswith('.'): |
| del_dir_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE|assets|vendor|tmp|static|templates)'), dir) |
| if len(res_abort): |
| del_dir_index.append(i) |
| |
| |
| del_dir_index = list(set(del_dir_index)) |
| del_dir_index.sort() |
| for counter, index in enumerate(del_dir_index): |
| index = index - counter |
| dirs.pop(index) |
| |
| |
| del_file_index = [] |
| for i, file in enumerate(files): |
| |
| |
| if file.startswith('.'): |
| del_file_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(_NOTE\.md|\.d\.ts|\.lock|\.png|\.woff2|\.ttf|\.woff|\.css|README\.md|\.toml|swagger-ui-bundle.js|-lock\.json)$'), |
| file) |
| if len(res_abort): |
| del_file_index.append(i) |
| |
| |
| del_file_index = list(set(del_file_index)) |
| del_file_index.sort() |
| for counter, index in enumerate(del_file_index): |
| index = index - counter |
| files.pop(index) |
| |
| |
| for file in files: |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|js|ts|html|go|mod|json)$'), file) |
| if len(res_save): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| def get_deep_dirs_fast(path): |
| global exclude_dirs |
| global exclude_files |
| global include_exts |
| |
| |
| |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| dirs[:] = [d for d in dirs if not d.startswith('.') and not any(ex in d for ex in exclude_dirs)] |
| |
| files[:] = [f for f in files if not f.startswith('.') and not any(ex in f for ex in exclude_files)] |
| |
| for file in files: |
| |
| if any(file.endswith(ext) for ext in include_exts): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| |
| |
| def readcode_writemd(file_path,root_path ,md_file_path): |
| suffix = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file_path) |
| if len(suffix): |
| suffix = suffix[0][1:] |
| with open(file_path, "r", encoding='utf-8') as f: |
| try: |
| rest_line = f.read() |
| except Exception as e: |
| print(f'{file_path}文件编码读取错误,非utf-8') |
| rest_line = '' |
| write2md(rest_line,suffix, file_path, root_path,md_file_path) |
| |
| |
| |
| def get_md_title_path(file_path,root_path): |
| |
| common_prefix = os.path.commonprefix([file_path, root_path]) |
| |
| diff1 = file_path[len(common_prefix)+1:] |
| |
| |
| |
| md_title = os.path.join(os.path.basename(root_path),diff1) |
| return md_title |
| |
| |
| def get_code_md_lable_by_suffix(suffix): |
| global md_suffix_table |
| |
| if md_suffix_table.get(suffix) is not None: |
| return md_suffix_table.get(suffix) |
| |
| return suffix |
| |
| |
| def write2md(content, suffix, file_path,root_path, md_file_path): |
| with open(md_file_path, "a", encoding='utf-8') as f: |
| md_title = get_md_title_path(file_path,root_path) |
| f.write(f"# `{md_title}`\n\n") |
| f.write(f"```{get_code_md_lable_by_suffix(suffix)}\n") |
| f.write(content) |
| f.write(f"\n") |
| f.write(f"```\n\n\n") |
| |
| |
| |
| def get_root_path(path): |
| dir_path = path |
| |
| if os.path.isfile(path): |
| dir_path = os.path.dirname(path) |
| return dir_path |
| |
| |
| |
| def get_file_name(): |
| |
| now = datetime.now() |
| |
| time_str = now.strftime('%Y-%m-%d_%H-%M-%S') |
| |
| file_name = f'Z_{time_str}_NOTE.md' |
| return file_name |
| |
| |
| |
| |
| if __name__ == '__main__': |
| root_path = get_root_path(sys.argv[1]) |
| md_file_name = get_file_name() |
| md_file_path = os.path.join(root_path, md_file_name) |
| |
| file_path_list = get_deep_dirs_fast(root_path) |
| |
| |
| for i,file_path in enumerate(file_path_list): |
| print(i,'->',get_md_title_path(file_path,root_path)) |
| readcode_writemd(file_path, root_path,md_file_path) |
| |
| print('=============done=============') |
| |
| |
| |
code2md/judge.command
| #!/bin/bash |
| read -p "Enter file path: " file_path |
| |
| is_alias=$(GetFileInfo -aa "$file_path") |
| |
| if [ "$is_alias" == "1" ]; then |
| echo "yes" |
| else |
| echo "no" |
| fi |
| |
code2md/run.command
| #! /bin/bash |
| |
| source /Users/song/Code/script_python/code2md/venv/bin/activate |
| |
| python /Users/song/Code/script_python/code2md/main.py |
| |
| |
code2md/main.py
| |
| |
| import os |
| import re |
| import shutil |
| |
| import easygui |
| from easygui import * |
| |
| from pathlib import Path |
| |
| |
| class User(EgStore): |
| def __init__(self, filename): |
| self.path = '' |
| EgStore.__init__(self, filename) |
| |
| |
| def get_dir_path_gui(): |
| |
| user = User("settings.txt") |
| |
| user.restore() |
| file_path = easygui.diropenbox(default=user.path) |
| user.path = file_path |
| user.store() |
| return file_path |
| |
| |
| def get_root_dir(dir_path): |
| file_list = os.listdir(dir_path) |
| path_list = [] |
| root_file_list = [] |
| for file in file_list: |
| print(file) |
| |
| if file.startswith('.'): |
| continue |
| |
| is_file = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file) |
| if len(is_file): |
| |
| res_abort = re.findall(re.compile( |
| r'(d\.ts|config\.ts|-lock\.json)$'), file) |
| if res_abort: |
| continue |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|config\.js|js|ts|html|txt|go|mod|json)$'), file) |
| if len(res_save): |
| root_file_list.append(file) |
| continue |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE)'), file) |
| if len(res_abort): |
| continue |
| |
| file_path = os.path.join(dir_path, file) |
| path_list.append(file_path) |
| return path_list, root_file_list |
| |
| |
| def get_deep_dirs(path): |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| |
| del_dir_index = [] |
| for i, dir in enumerate(dirs): |
| |
| if dir.startswith('.'): |
| del_dir_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE|assets|vendor|tmp|static|templates)'), dir) |
| if len(res_abort): |
| del_dir_index.append(i) |
| |
| |
| del_dir_index = list(set(del_dir_index)) |
| del_dir_index.sort() |
| for counter, index in enumerate(del_dir_index): |
| index = index - counter |
| dirs.pop(index) |
| |
| |
| del_file_index = [] |
| for i, file in enumerate(files): |
| |
| |
| if file.startswith('.'): |
| del_file_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(\.d\.ts|\.lock|\.png|\.woff2|\.ttf|\.woff|\.css|README\.md|\.toml|swagger-ui-bundle.js|-lock\.json)$'), |
| file) |
| if len(res_abort): |
| del_file_index.append(i) |
| |
| |
| del_file_index = list(set(del_file_index)) |
| del_file_index.sort() |
| for counter, index in enumerate(del_file_index): |
| index = index - counter |
| files.pop(index) |
| |
| |
| for file in files: |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|js|ts|html|go|mod|json)$'), file) |
| if len(res_save): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| |
| def readcode_writemd(file_path, root_path): |
| suffix = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file_path) |
| if len(suffix): |
| suffix = suffix[0][1:] |
| with open(file_path, "r", encoding='utf-8') as f: |
| head_line = f.readline() |
| rest_line = f.read() |
| write2md(head_line, head_line + rest_line, |
| suffix, file_path, root_path) |
| |
| |
| def write2md(head, content, suffix, file_path, root_path): |
| with open(root_path + '/NOTE.md', "a", encoding='utf-8') as f: |
| f.write(f"# `{file_path}`\n\n") |
| |
| f.write(f"```{suffix}\n") |
| f.write(content) |
| f.write(f"\n") |
| f.write(f"```\n") |
| |
| |
| if __name__ == '__main__': |
| root_path = get_dir_path_gui() |
| md_file = os.path.join(root_path, '====NOTE.md') |
| |
| |
| if os.path.exists(md_file): |
| os.remove(md_file) |
| |
| file_path_list = get_deep_dirs(root_path) |
| for file_path in file_path_list: |
| print(file_path) |
| readcode_writemd(file_path, root_path) |
| print('!!!complete!!!') |
| os.system('open '+root_path) |
| |
code2md/get_all_files.py
| |
| import os |
| import subprocess |
| import re |
| import shutil |
| import sys |
| from pathlib import Path |
| from datetime import datetime |
| |
| |
| |
| def get_root_dir(dir_path): |
| file_list = os.listdir(dir_path) |
| path_list = [] |
| root_file_list = [] |
| for file in file_list: |
| print(file) |
| |
| if file.startswith('.'): |
| continue |
| |
| is_file = re.findall(r'\.[^.\\/:*?"<>|\r\n]+$', file) |
| if len(is_file): |
| |
| res_abort = re.findall(re.compile( |
| r'(d\.ts|config\.ts|-lock\.json)$'), file) |
| if res_abort: |
| continue |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|config\.js|js|ts|html|txt|go|mod|json)$'), file) |
| if len(res_save): |
| root_file_list.append(file) |
| continue |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE)'), file) |
| if len(res_abort): |
| continue |
| |
| file_path = os.path.join(dir_path, file) |
| path_list.append(file_path) |
| return path_list, root_file_list |
| |
| |
| def get_deep_dirs(path): |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| print(dirs) |
| print(files) |
| |
| print('--------------------') |
| |
| wait_del_dir_idxs = [] |
| for i, dir in enumerate(dirs): |
| |
| if dir.startswith('.'): |
| wait_del_dir_idxs.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(__pycache__|venv|build|dist|node_modules|public|LICENSE|assets|vendor|tmp|static|templates)'), dir) |
| if len(res_abort): |
| wait_del_dir_idxs.append(i) |
| |
| |
| |
| wait_del_dir_idxs = list(set(wait_del_dir_idxs)) |
| wait_del_dir_idxs.sort() |
| for counter, index in enumerate(wait_del_dir_idxs): |
| index = index - counter |
| dirs.pop(index) |
| |
| |
| del_file_index = [] |
| for i, file in enumerate(files): |
| |
| |
| if file.startswith('.'): |
| del_file_index.append(i) |
| |
| res_abort = re.findall(re.compile( |
| r'(_NOTE\.md|\.d\.ts|\.lock|\.png|\.woff2|\.ttf|\.woff|\.css|README\.md|\.toml|swagger-ui-bundle.js|-lock\.json)$'), |
| file) |
| if len(res_abort): |
| del_file_index.append(i) |
| |
| |
| del_file_index = list(set(del_file_index)) |
| del_file_index.sort() |
| for counter, index in enumerate(del_file_index): |
| index = index - counter |
| files.pop(index) |
| |
| |
| for file in files: |
| |
| res_save = re.findall(re.compile(r'(\.py|vue|js|ts|html|go|mod|json)$'), file) |
| if len(res_save): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| |
| |
| |
| |
| def get_deep_dirs_fast(path, exclude_dirs=None, exclude_files=None, include_exts=None): |
| |
| if exclude_dirs is None: |
| exclude_dirs = ['__pycache__', 'venv', 'build', 'dist', 'node_modules', 'public', 'LICENSE', 'assets', 'vendor', 'tmp', 'static', 'templates'] |
| |
| if exclude_files is None: |
| exclude_files = ['_NOTE.md', '.d.ts', '.lock', '.png', '.woff2', '.ttf', '.woff', '.css', 'README.md', '.toml', 'swagger-ui-bundle.js', '-lock.json'] |
| |
| if include_exts is None: |
| include_exts = ['.py', '.vue', '.js', '.ts', '.html', '.go', '.mod', '.json','.txt'] |
| |
| file_path = [] |
| for root, dirs, files in os.walk(path): |
| |
| dirs[:] = [d for d in dirs if not d.startswith('.') and not any(ex in d for ex in exclude_dirs)] |
| |
| files[:] = [f for f in files if not f.startswith('.') and not any(ex in f for ex in exclude_files)] |
| |
| for file in files: |
| |
| if any(file.endswith(ext) for ext in include_exts): |
| file_path.append(os.path.join(root, file)) |
| return file_path |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| if __name__ == '__main__': |
| root_path = "/Users/song/Code/agv_frontend" |
| file_path_list = get_deep_dirs_fast(root_path) |
| for file_path in file_path_list: |
| print(file_path) |
| |
| print(f'=============done_{len(file_path_list)}=============') |
| |
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
2022-06-22 遥控按键在安卓系统上面的键值