title: Markdown et Python [Suite](/david/stream/2015/01/25/) des utilitaires utilisés pour générer ce site. J’ai une arborescence de fichiers markdown que je transforme en fichiers `HTML`. Je commence donc par les récupérer : :::python def each_markdown_from(source_dir, file_name='index.md'): """Walk across the `source_dir` and return the md file path.""" for root, dirnames, filenames in os.walk(source_dir): for filename in fnmatch.filter(filenames, file_name): yield os.path.join(root, filename) Ce petit utilitaire parcoure un dossier et retourne le chemin d’accès s’il contient `index.md`. J’ai une seconde fonction qui me permet de parser un fichier markdown et de compiler le contenu avec ses méta-données : :::python def parse_markdown(file_path, extensions=None): """Parse an md file and returns its converted content and metadata.""" if extensions is None: extensions = ['meta', 'codehilite'] parser = markdown.Markdown(extensions=extensions) with codecs.open(file_path, 'r', 'utf-8') as source: content = parser.convert(source.read()) return content, hasattr(parser, 'Meta') and parser.Meta or None En combinant les deux, on obtient la boucle suivante : :::python for file_path in each_markdown_from(POSTS_PATH): content, metadata = parse_markdown(file_path) Dans [un prochain épisode](/david/stream/2015/02/12/), on verra comment utiliser les `namedtuple`s à bon escient.