|
1234567891011121314151617181920212223242526272829303132 |
- 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.
|