Soleris_Roman/reecrire-lien.py

55 lines
No EOL
2 KiB
Python

import os
import re
import argparse
def process_file(file_path):
"""
Lit un fichier .md, remplace les séquences de mots/phrases séparées par '/' qui commencent par 'Univers étendue'
par le dernier mot/phrase, et écrit le fichier modifié.
"""
with open(file_path, 'r', encoding='utf-8') as f:
content = f.read()
# Pattern : commence par 'Univers étendue' suivi d'au moins un '/', où chaque partie peut contenir des espaces mais pas de '/'
# Ex: "Univers étendue/Personnages/Secondaires/Namisse"
pattern = r'Univers étendue(?:/[^/]+)+'
def replace_chain(match):
# Prend le dernier élément après le dernier '/'
last_part = match.group(0).rsplit('/', 1)[-1].strip()
return last_part
new_content = re.sub(pattern, replace_chain, content)
with open(file_path, 'w', encoding='utf-8') as f:
f.write(new_content)
print(f"Séquences remplacées dans : {file_path}")
def main():
parser = argparse.ArgumentParser(description="Parcourt un dossier et ses sous-dossiers, remplace les chaînes 'Univers étendue/mot1/mot2/mot3' par 'mot3' dans tous les fichiers .md.")
parser.add_argument('dossier', help="Chemin du dossier à parcourir (ex: '/chemin/vers/votre/vault')")
args = parser.parse_args()
dossier = args.dossier
if not os.path.exists(dossier):
print(f"Erreur : Le dossier '{dossier}' n'existe pas.")
return
# Parcours récursif des fichiers .md
processed_count = 0
for root, dirs, files in os.walk(dossier):
for file in files:
if file.endswith('.md'):
file_path = os.path.join(root, file)
try:
process_file(file_path)
processed_count += 1
except Exception as e:
print(f"Erreur lors du traitement de {file_path} : {e}")
print(f"\nTerminé ! {processed_count} fichiers .md traités.")
if __name__ == "__main__":
main()