MarkDown Mkdocs-Material pour le contenu#
Introduction#
Markdown est un langage de description à balisage plus léger à coder que des balises HTML.
Son code est plus lisible dans l'éditeur,
plus pratique et rapide pour rédiger et publier un document sur le Web.
Cliquer sur les onglets ci-dessus pour comparer les codes MarkDown et HTML qui produisent ce même Rendu
Le principal défaut de MarkDown est son manque d'unification : il existe plusieurs versions de ce langage qui, à partir d'une syntaxe de base commune, possèdent d'autres éléments additionnels souvent très spécifiques...
Cependant il est de plus en plus utilisé :
- incontournable sur GitHub,
- le site de partage d'informations Reddit,
- l'éditeur collaboratif en ligne HedgeDoc,
- les forums Discourse, Stack Overflow...
Mais c'est surtout le langage que nous utiliserons pour rédiger du texte enrichi dans nos notebook jupyter et nos pages web rédigées avec le MarkDown de Mkdocs tel que présenté ici.
Remarque :
Vous avez toujours la possibilité de coder en HTML dans les
fichiers.md
de Mkdocs, comme dans les cellules MarkDown d'un notebook jupyter...Par exemple, pour écrire des commentaires dans un code en MarkDown on utilise la syntaxe HTML :
<!-- mon commentaire -->
![Logo]{ align=left }
[**Markdown**][1]{target="_blank"} est un langage de description à balisage plus léger à coder que des balises HTML.
Son code est plus lisible dans l'éditeur,
plus pratique et rapide pour rédiger et publier un document sur le Web.
> Cliquer sur les onglets ci-dessus pour comparer les codes **MarkDown** et **HTML** qui produisent ce même **Rendu**
Le principal défaut de MarkDown est son manque d'unification :
il existe plusieurs versions de ce langage qui,
à partir d'une syntaxe de base commune,
possèdent d'autres éléments additionnels souvent très spécifiques...
Cependant il est de plus en plus utilisé :
- incontournable sur [GitHub]{target="_blank"},
- le site de partage d'informations [Reddit]{target="_blank"},
- l'éditeur collaboratif en ligne [HedgeDoc]{target="_blank"},
- les forums [Discourse]{target="_blank"},
[Stack Overflow]{target="_blank"}...
Mais c'est surtout le langage que nous utiliserons pour rédiger du texte enrichi
dans nos [notebook jupyter][bn-md]{target="_blank"}
et nos pages web rédigées avec le MarkDown de Mkdocs tel que présenté ici.
> **Remarque** :
>
> Vous avez toujours la possibilité de coder en HTML
dans les `fichiers.md` de Mkdocs,
comme dans les cellules MarkDown
d'un [notebook jupyter][bn-html]{target="_blank"}...
>
> Par exemple, pour écrire des commentaires dans un code en MarkDown
on utilise la syntaxe HTML : `<!-- mon commentaire -->`
<!-- Ceci est un commentaire qui ne sera donc pas affiché
Liste des liens pour l'introduction : -->
[1]: https://fr.wikipedia.org/wiki/Markdown "Page Markdown sur Wikipedia"
[GitHub]: https://guides.github.com/features/mastering-markdown/ "Guide MarkDown de GitHub"
[Reddit]: https://www.reddit.com/wiki/markdown "Guide MarkDown de Reddit"
[HedgeDoc]: https://demo.hedgedoc.org/features?both "Page de demonstration du Markdown de HedgeDoc"
[Discourse]: https://forum.digikey.com/t/an-unofficial-discourse-user-reference-guide/1125/4 "Référence MarkDown pour Discourse"
[Stack Overflow]: https://stackoverflow.com/editing-help "Aide Markdown de Stack Overflow"
[bn-md]: ../MarkDown-Le_BN_pour_rapporter "Notebook d'initiation au Markdown de Jupyter"
[bn-html]: ../HTML-Le_BN_pour_multimedier "Notebook d'initiation au HTML de Jupyter"
[Logo]: https://upload.wikimedia.org/wikipedia/commons/4/48/Markdown-mark.svg "Logo du langage MarkDown"
<img src="https://upload.wikimedia.org/wikipedia/commons/4/48/Markdown-mark.svg" align="left" title="Logo du langage MarkDown" alt="Logo du langage MarkDown">
<p>
<a href="https://fr.wikipedia.org/wiki/Markdown" target="_blank" title="Page Markdown sur Wikipedia"><strong>Markdown</strong></a>
est un langage de description à balisage plus léger à coder que des balises HTML.
<br>
Son code est plus lisible dans l'éditeur,
plus pratique et rapide pour rédiger et publier un document sur le Web.
</p>
<blockquote>
<p>
Cliquer sur les onglets ci-dessus pour comparer les codes <strong>MarkDown</strong>
et <strong>HTML</strong> qui produisent ce même <strong>Rendu</strong>
</p>
</blockquote>
<p>
Le principal défaut de MarkDown est son manque d'unification :
il existe plusieurs versions de ce langage qui,
à partir d'une syntaxe de base commune,
possèdent d'autres éléments additionnels souvent très spécifiques...
</p>
<p>
Cependant il est de plus en plus utilisé :
<ul>
<li>
incontournable sur <a href="https://guides.github.com/features/mastering-markdown/" target="_blank" title="Guide MarkDown de GitHub">GitHub</a>,
</li>
<li>
le site de partage d'informations <a href="https://www.reddit.com/wiki/markdown" target="_blank" title="Guide MarkDown de Reddit">Reddit</a>,
</li>
<li>
l'éditeur collaboratif en ligne <a href="https://demo.hedgedoc.org/features?both" target="_blank" title="Page de demonstration du Markdown de HedgeDoc">HedgeDoc</a>,
</li>
<li>
les forums <a href="https://forum.digikey.com/t/an-unofficial-discourse-user-reference-guide/1125/4" target="_blank" title="Référence MarkDown pour Discourse">Discourse</a>,
<a href="https://stackoverflow.com/editing-help" target="_blank" title="Aide Markdown de Stack Overflow">Stack Overflow</a>...
</li>
</ul>
Mais c'est surtout le langage que nous utiliserons pour rédiger du texte enrichi
dans nos <a href="../MarkDown-Le_BN_pour_rapporter" target="_blank" title="Notebook d'initiation au Markdown de Jupyter">notebook jupyter</a>
et nos pages web rédigées avec le MarkDown de Mkdocs tel que présenté ici.
</p>
<blockquote>
<p>
<strong>Remarque</strong> :
</p>
<p>
Vous avez toujours la possibilité de coder en HTML
dans les <code>fichiers.md</code> de Mkdocs,
comme dans les cellules MarkDown d'un
<a href="../HTML-Le_BN_pour_multimedier" target="_blank" title="Notebook d'initiation au HTML de Jupyter">notebook jupyter</a>...
</p>
<p>
Par exemple, pour écrire des commentaires dans un code en MarkDown
on utilise la syntaxe HTML : <code><!-- mon commentaire --></code>
</p>
</blockquote>
<!-- Ceci est un commentaire qui ne sera donc pas affiché -->
Markdown
est un langage de description à balisage plus léger à coder que des balises HTML.
Son code est plus lisible dans l'éditeur,
plus pratique et rapide pour rédiger et publier un document sur le Web.
Cliquer sur les onglets ci-dessus pour comparer les codes MarkDown et HTML qui produisent ce même Rendu
Le principal défaut de MarkDown est son manque d'unification :
il existe plusieurs versions de ce langage qui,
à partir d'une syntaxe de base commune,
possèdent d'autres éléments additionnels souvent très spécifiques...
Cependant il est de plus en plus utilisé :
- incontournable sur GitHub,
- le site de partage d'informations Reddit,
- l'éditeur collaboratif en ligne HedgeDoc,
- les forums Discourse, Stack Overflow...
Remarque :
Vous avez toujours la possibilité de coder en HTML dans les
fichiers.md
de Mkdocs, comme dans les cellules MarkDown d'un notebook jupyter...Par exemple, pour écrire des commentaires dans un code en MarkDown on utilise la syntaxe HTML :
<!-- mon commentaire -->
Titres#
# Titre de niveau 1
## Titre de niveau 2
### Titre de niveau 3
#### Titre de niveau 4
##### Titre de niveau 5
###### Titre de niveau 6
####### Il n'y a pas de titre de niveau 7
Autres solutions pour obtenir des titres de niveau 1 et 2 :
Souligner avec des `=` produit un titre de niveau 1
===================================================
Souligner avec des `-` produit un titre de niveau 2
---------------------------------------------------
Remarque :
Un seul =
ou -
suffirait.
Leur répétition permet de souligner ces titres
également dans le code en mode édition.
Titres, titre de page et table des matières automatique : ...
-
En pratique, un fichier MarkDown
source.md
du dossierdocs
ne doit comporter, au plus, qu'un titre de niveau 1 qui peut potentiellement devenir le titre de la page web. De même pour un Notebook Jupytersource.ipynb
du dossierdocs
. -
A partir des titres de niveau 2, MkDocs génère automatiquement une table des matières pour naviguer dans la page courante.
La profondeur des sous-titres souhaités est réglable. Une profondeur fixée à la valeur 0 désactive l'affichage de la table des matières.
Pour cela, il faut activer dans le fichier mkdocs.yml
l'extension
toc
(table of contents) en précisant les options souhaitées : plus petit niveau de titre à intégrer, ajout de lien vers les ancres des titres,...
Par exemple pour ce site :
markdown_extensions:
- toc: # Table des matières générée automatiquement à partir des titres du niveau 2
permalink: "#" # Ajoute un symbole lien hypertexte vers l'ancre du titre #le-titre
toc_depth: 4 # Limite de la profondeur d'inclusion des titres dans la table des matières
Corps de texte#
On peut obtenir du texte avec simple emphase rendu en italique,
du texte avec forte emphase rendu en Gras,
du Texte à la fois en gras et en italique,
du code source
rendu en caractères monospaces
,
du texte barré rendu avec une ligne en travers du texte,
du texte souligné rendu avec une ligne en dessous du texte.
On peut aussi mettre en indice ou en exposant et même surligné.
En regardant le code qui produit cette phrase, vous remarquerez que même si on fait des retours à la ligne dans le code, le texte s'affiche sans rupture dans un seul et même paragraphe et les espaces laissés en trop sont supprimés...
Pour former des paragraphes séparés, il faut laisser une ligne vide entre eux.
Pour forcer le retour à la ligne dans un paragraphe,
il faut ajouter deux espaces à la fin d'une ligne
avant de faire un retour à la ligne...
On peut obtenir du _texte_ avec *simple emphase* rendu en *italique*,
du __texte__ avec **forte emphase** rendu en **Gras**,
du **_Texte_** à la fois en **gras** et en *italique*,
du `code source` rendu en caractères `monospaces`,
du ~~texte barré~~ rendu avec une ligne en travers du texte,
du ^^texte souligné^^ rendu avec une ligne en dessous du texte.
On peut aussi mettre en ~indice~ ou en ^exposant^ et même ==surligné==.
En regardant le code
qui produit cette phrase,
vous remarquerez que
même
si
on
fait
des
retours
à
la
ligne
dans
le
code,
le texte s'affiche sans rupture
dans un seul et même paragraphe
et les espaces laissés en trop sont supprimés...
Pour former des paragraphes séparés, il faut laisser une ligne vide entre eux.
Pour forcer le retour à la ligne dans un paragraphe,
il faut ajouter deux espaces à la fin d'une ligne
avant de faire un retour à la ligne...
Complément pour ajouter des marquages et commentaires de révision : ...
Du texte, comme du code, peuvent être révisés1 :
à enlever ou à ajouter ;
Ceci peut être fait en deuxune seule opération.
Et aussi surligné avec un commentaire lié.
Un formatage peut être appliqué à tout un bloc de lignes et paragraphes :
- Il faut commencer par un saut de ligne pour commencer un nouveau bloc ;
- Puis l'encadrer globalement entre les balises ouvrantes et fermantes souhaitées, disposées chacune sur leur propre ligne ;
- Sans oublier de laisser un saut de ligne avant et après le contenu à marquer.
Du texte, comme du code, peuvent être révisés[^critic] :
à enlever ou à ajouter ;
Ceci peut être fait en deuxune seule opération.
Et aussi surligné avec un commentaire lié.
Un formatage peut être appliqué à tout un bloc de lignes et paragraphes :
* Il faut commencer par un saut de ligne pour commencer un nouveau bloc ;
* Puis l'encadrer globalement entre les balises ouvrantes et fermantes souhaitées,
disposées chacune sur leur propre ligne ;
* Sans oublier de laisser un saut de ligne avant et après le contenu à marquer.
Astuces pour obtenir au clavier les caractères spéciaux comme ~
, `
, {
ou }
: ...
- Le tilde s'obtient avec la combinaison de touches AltGr+é ;
- L'accent grave s'obtient avec la combinaison de touches AltGr+è ;
- Les accolades (braces) ouvrante et fermante s'obtiennent respectivement avec les combinaisons de touches AltGr+' et AltGr+=
Info
Il faut activer dans le fichier mkdocs.yml
les extensions :
markdown_extensions:
- pymdownx.caret
- pymdownx.mark
- pymdownx.tilde
- pymdownx.critic
- pymdownx.caret pour
^^souligné^^
ou mettre en^exposant^
; - pymdownx.mark pour
==surligné==
; - pymdownx.tilde pour
~~barré~~
ou mettre en~indice~
; - pymdownx.critic pour du marquage et des commentaires de révision.
Lien#
Le plus simple pour intégrer un lien hypertexte est de coller son adresse
directement entre deux chevrons `<URL>` comme par exemple : <https://www.mkdocs.org/> ;
De cette façon on peut aussi indiquer une adresse `<mail>` : <prenom.nom@ecmorlaix.fr>.
La syntaxe `[texte](adresse "info-bulle")` lie une adresse à un texte support
avec l'affichage optionnel d'une info-bulle au survol du lien :
par exemple, voici [un lien relatif](./#introduction "Introduction au MarkDown de Mkdocs avec Material")
vers l'introduction de cette page, et
[un lien absolu]( https://ericecmorlaix.github.io/adn-Tutoriel_site_web/MarkDown-Mkdocs_Material/#introduction
"Introduction au MarkDown de Mkdocs avec Material") qui renvoie au même titre.
Le plus simple pour intégrer un lien hypertexte est de coller son adresse
directement entre deux chevrons <URL>
comme par exemple : https://www.mkdocs.org/ ;
De cette façon on peut aussi indiquer une adresse <mail>
: prenom.nom@ecmorlaix.fr.
La syntaxe [texte](adresse "info-bulle")
lie une adresse à un texte support
avec l'affichage optionnel d'une info-bulle au survol du lien :
par exemple, voici un lien relatif
vers l'introduction de cette page, et
un lien absolu qui renvoie au même titre.
Parce que de longues adresses de liens dégradent la lisibilité du texte en mode édition de code,
MarkDown permet de définir des liens par référence.
Dans ce cas, on définit tous les liens à un endroit du document,
en dehors du texte (généralement rassemblé),
avec la syntaxe :
[référence]: adresse "info-bulle"
[texte][référence]
ou encore tout simplement [référence]
. Cette solution offre aussi l'avantage de pouvoir partager la même adresse par plusieurs liens en ne la définissant qu’une fois dans le document.
Pour exemple :
Le code MarkDown du paragraphe d'introduction comporte de nombreux liens de ce type, tous listés à la fin du texte de cette partie :
![Logo]{ align=left }
[**Markdown**][1]{target="_blank"} est un langage de description à balisage plus léger à coder que des balises HTML.
Son code est plus lisible dans l'éditeur,
plus pratique et rapide pour rédiger et publier un document sur le Web.
> Cliquer sur les onglets ci-dessus pour comparer les codes **MarkDown** et **HTML** qui produisent ce même **Rendu**
Le principal défaut de MarkDown est son manque d'unification :
il existe plusieurs versions de ce langage qui,
à partir d'une syntaxe de base commune,
possèdent d'autres éléments additionnels souvent très spécifiques...
Cependant il est de plus en plus utilisé :
- incontournable sur [GitHub]{target="_blank"},
- le site de partage d'informations [Reddit]{target="_blank"},
- l'éditeur collaboratif en ligne [HedgeDoc]{target="_blank"},
- les forums [Discourse]{target="_blank"},
[Stack Overflow]{target="_blank"}...
Mais c'est surtout le langage que nous utiliserons pour rédiger du texte enrichi
dans nos [notebook jupyter][bn-md]{target="_blank"}
et nos pages web rédigées avec le MarkDown de Mkdocs tel que présenté ici.
> **Remarque** :
>
> Vous avez toujours la possibilité de coder en HTML
dans les `fichiers.md` de Mkdocs,
comme dans les cellules MarkDown
d'un [notebook jupyter][bn-html]{target="_blank"}...
>
> Par exemple, pour écrire des commentaires dans un code en MarkDown
on utilise la syntaxe HTML : `<!-- mon commentaire -->`
<!-- Ceci est un commentaire qui ne sera donc pas affiché
Liste des liens pour l'introduction : -->
[1]: https://fr.wikipedia.org/wiki/Markdown "Page Markdown sur Wikipedia"
[GitHub]: https://guides.github.com/features/mastering-markdown/ "Guide MarkDown de GitHub"
[Reddit]: https://www.reddit.com/wiki/markdown "Guide MarkDown de Reddit"
[HedgeDoc]: https://demo.hedgedoc.org/features?both "Page de demonstration du Markdown de HedgeDoc"
[Discourse]: https://forum.digikey.com/t/an-unofficial-discourse-user-reference-guide/1125/4 "Référence MarkDown pour Discourse"
[Stack Overflow]: https://stackoverflow.com/editing-help "Aide Markdown de Stack Overflow"
[bn-md]: ../MarkDown-Le_BN_pour_rapporter "Notebook d'initiation au Markdown de Jupyter"
[bn-html]: ../HTML-Le_BN_pour_multimedier "Notebook d'initiation au HTML de Jupyter"
[Logo]: https://upload.wikimedia.org/wikipedia/commons/4/48/Markdown-mark.svg "Logo du langage MarkDown"
Astuce pour faire ouvrir la page liée dans un nouvel onglet :
Par défaut, et contrairement à jupyter notebook, MkDocs ouvre la page web liée dans le même onglet que le document consulté.
L'extension attr_list
activée dans le fichier mkdocs.yml
permet de préciser des valeurs personnalisées aux attributs HTML et CSS.
Ainsi la syntaxe {target="_blank"}
après le code d'un lien MarkDown modifie la valeur par défaut de l'attribut
target
afin d'ouvrir la page liée dans un nouvel onglet.
En résumé, la syntaxe complète en markdown d'un lien avec ce comportement est donc :
- en ligne dans le texte :
[mon texte support](https://monlien.com "mon info-bulle"){target="_blank"}
- par référence :
- dans le texte :
[référence]{target="_blank"}
- hors du texte
[référence]: https://monlien.com "mon info-bulle"
- dans le texte :
Image#
La syntaxe pour les images est la même que pour les liens hypertextes,
mais avec un !
devant :
![texte alternatif](adresse "info-bulle")
Il est important de bien choisir le texte alternatif qui s'affichera lorsque l'image n'est pas disponible, car il permet aussi l'accessibilité pour les non-voyants et apporte de la sémantique pour les moteurs de recherche...
L'adresse est l'URL relative ou absolue qui permet d'atteindre le fichier lié en cheminant dans l'arborescence du site web, sachant que le dossier docs
du projet MkDocs (cf. branche main
du dépot GitHub) devient la racine du site
une fois déployé (cf. branche gh-pages
du dépot GitHub) :
Exemple :
![Illustration d'une photo instantané](../images/undraw_Polaroid.svg "image via URL relative")
![Illustration d'une photo instantané](https://ericecmorlaix.github.io/adn-Tutoriel_site_web/images/undraw_Polaroid.svg "image via URL absolue")
Ce qui permet d'ajouter facilement un [lien pour ouvrir cette image][polaroïd]{ target="_blank"} dans un nouvel onglet...
![polaroïd]
<!-- Une seule et même référence pour le lien et l'image, une référence plusieurs fois réutilisable dans ce document... -->
[polaroïd]: https://ericecmorlaix.github.io/adn-Tutoriel_site_web/images/undraw_Polaroid.svg "Illustration d'une photo instantané"
Ici le fichier de l'image est placé dans un dossier nommé images
lui même situé dans le dossier docs
:
├── docs/
│ └── images/
│ │ └── undraw_Polaroid.svg
│ └── MarkDown-Mkdocs_Material.md
│ └── index.md
└─ mkdocs.yml
images
sera à la racine du site :
└── site/
├── images/
│ └── undraw_Polaroid.svg
├── MarkDown-Mkdocs_Material/
│ ├── MarkDown-Mkdocs_Material.md
│ ├── index.html
├── index.md
├── index.html
├── 404.html
index.html
située dans le dossier MarkDown-Mkdocs_Material
et
générée à partir du fichier MarkDown-Mkdocs_Material.md
sera ../images/undraw_Polaroid.svg
car il faut sortir du dossier MarkDown-Mkdocs_Material
pour pouvoir rentrer dans le dossier images
.
Remarque 1 :
Un chemin relatif vers cette même image depuis la page web index.html
située à la racine du site et
générée à partir du fichier index.md
serait ./images/undraw_Polaroid.svg
.
Pour gérer l'alignement et la taille d'une image :
L'extension attr_list
qui permet de préciser des valeurs personnalisées aux attributs HTML et CSS doit être activée dans le fichier mkdocs.yml
:
markdown_extensions:
- attr_list
Ainsi le code MarkDown suivant :
![polaroïd]{width=20% align=right}
![polaroïd]{width=20% align=right}
Ainsi le code MarkDown suivant :
```markdown
![polaroïd](../images/undraw_Polaroid.svg){width=20% align=right}
```
placé au début du texte de ce paragraphe, produit l'affichage de l'image tel que ci-contre.
Une explication en vidéo par Fred LELEU :
Une image cliquable, support d'un lien :
Il suffit de remplacer le texte support d'un lien hypertexte par le code MarDown d'une image tel que :
[![texte alternatif](adresse)](adresse "info-bulle")
Des solutions pour centrer une image :
Solution 1 : un code HTML...
<figure>
<img src="../images/undraw_Polaroid.svg" alt="Illustration d'une photo instantané" width="300" >
<figcaption>
Un Polaroïd selon <a href="https://undraw.co/illustrations">unDraw</a>
</figcaption>
</figure>
Pour une largeur en %, l'image est décalée par rapport à sa légende...
<figure>
<img src="../images/undraw_Polaroid.svg" alt ="Illustration d'une photo instantané" width="50%" >
<figcaption>
Un Polaroïd selon <a href="https://undraw.co/illustrations">unDraw</a>
</figcaption>
</figure>
Ce décalage n'apparait pas pour une largeur indiquée en px ou en em.
Une explication en vidéo par Fred LELEU :
Solution 2 : un code MarkDown...
L'extension attr_list
qui permet de préciser des valeurs personnalisées aux attributs HTML et CSS doit être activée dans le fichier mkdocs.yml
:
markdown_extensions:
- attr_list
docs/stylesheet/extra.css
(Merci à Gilles) :
.center {
display: block;
margin: 0 auto;
}
L’insertion d’une image peut se faire maintenant avec la syntaxe :
![texte alternatif](adresse "info-bulle"){ .center }
![polaroïd]{ width="30%" .center }
Même avec une largeur en %, l'image est centrée mais il n'y a pas de légende centrée possible.
Solution 3 : un code hybride...
En plus de l'extension attr_list
qui permet de préciser des valeurs personnalisées aux attributs HTML et CSS, il faut également activer dans le fichier mkdocs.yml
l'extension md_in_html qui permet d'écrire du code MarkDown à l'intérieur de balises HTML :
markdown_extensions:
- attr_list
- md_in_html
Comme pour la solution précédente, il faut ajouter la spécification CSS supplémentaire dans le fichier docs/stylesheet/extra.css
(Merci à Gilles) :
.center {
display: block;
margin: 0 auto;
}
Pour notre exemple, une syntaxe possible serait,
sans oublier d'inscrire markdown
dans les balises HTML qui contiendront du MarkDown :
<figure markdown>
![polaroïd]{ width="50%" .center }
<figcaption markdown>
Un Polaroïd selon [unDraw](https://undraw.co/illustrations){target="_blank"}
</figcaption>
</figure>
Quel format d'image pour le web ?
- JPEG (Joint Photographic Expert Group)
- Parfait pour les photos et visuels colorés, c’est le format compressé le plus utilisé sur le web.
- PNG (Portable Network Graphics)
- Idéal pour les images à fond transparent, graphique et logo.
- SVG (Graphics Interchange Format)
- Format adapté aux images vectorielles, permet de les déformer sans altérer la qualité.
- GIF (Graphics Interchange Format)
- Images animées idéale pour illustrer vos propos, fortement utilisé sur les réseaux sociaux.
Trait horizontal#
Une série d'au moins trois *
,
ou trois _
,
ou trois -
après un saut de ligne,
trace une ligne de séparation.
Une série d'au moins trois `*`,
***
ou trois `_`,
___
ou trois `-` après un saut de ligne,
---
trace une ligne de séparation.
Listes#
Liste à puces#
On commence par sauter une ligne, puis on place devant chaque item
un caractère -
, +
ou *
, suivi d'au moins d'une espace :
* Un élement de ma liste ;
Une précision concernant cet élément...
- Un autre élément de ma liste ;
* Un élément de ma sous-liste ;
* Un autre élément de ma sous-liste ;
+ Encore un autre élément de ma liste.
- Un élement de ma liste ;
Une précision concernant cet élément... - Un autre élément de ma liste ;
- Un élément de ma sous-liste ;
- Un autre élément de ma sous-liste ;
- Encore un autre élément de ma liste.
Liste ordonnées#
On procède de même, mais en précédant chaque item d'un nombre suivi d'un .
,
la numérotation se fait alors automatiquement indépendamment du nombre indiqué :
1. Le premier élement de ma liste ;
Une précision concernant cet élément...
1. Le second élément de ma liste ;
1. Le premier élément de ma sous-liste ;
72. Le second élément de ma sous-liste ;
1024. Le troisième élément de ma liste.
- Le premier élement de ma liste ;
Une précision concernant cet élément... - Le second élément de ma liste ;
- Le premier élément de ma sous-liste ;
- Le second élément de ma sous-liste ;
- Le troisième élément de ma liste.
Liste de taches#
On insère [ ]
ou [x]
devant chaque item
d'une liste non ordonnée pour ajouter des cases à cocher :
- [ ] Une tâche de ma todo liste ;
- [x] Une autre tâche de ma todo liste ;
- [x] une sous tâche de ma todo liste ;
- [ ] une autre sous tâche de ma todo liste ;
- [ ] Encore une autre tâche de ma todo liste.
- Une tâche de ma todo liste ;
- Une autre tâche de ma todo liste ;
- une sous tâche de ma todo liste ;
- une autre sous tâche de ma todo liste ;
- Encore une autre tâche de ma todo liste.
Info
Il faut activer dans le fichier mkdocs.yml
l'extension
pymdownx.tasklist
pour générer des listes de tâches avec des cases à cocher.
markdown_extensions:
- pymdownx.tasklist
Liste de description#
Sous la ligne d'un terme, on précède sa définition par un :
suivi d'au moins une espace :
**Premier terme** :
: Voici la définition du premier terme...
**Second terme** :
: Voici une définition pour le second terme...
: Voici une autre définition pour le second terme...
- Premier terme :
- Voici la définition du premier terme...
- Second terme :
- Voici une définition pour le second terme...
- Voici une autre définition pour le second terme...
Info
Il faut activer dans le fichier mkdocs.yml
l'extension
def_list
pour générer des listes de définitions.
markdown_extensions:
- def_list
Citation#
Pour créer un bloc de citation, il suffit d'ajouter un >
devant un paragraphe.
Les blocs de citation peuvent s'imbriqués tels que par exemple :
> Cette première ligne est incluse dans un bloc de citation.
>
> Cette seconde ligne l'est également.
>> Celle ci se situe dans un bloc de citation imbriqué...
Cette première ligne est incluse dans un bloc de citation.
Cette seconde ligne l'est également.
Celle ci se situe dans un bloc de citation imbriqué...
On peut utiliser les blocs de citation pour souligner un point, comme par exemple :
ATTENTION !
Toto est dans la place...
Ceci est une mise en garde, vous voilà prévenu !!
> :warning: **ATTENTION !**
>
> **Toto** est dans la place...
>
> *Ceci est une mise en garde,
vous voilà prévenu !!*
Mais pour cela, MkDocs-Material offre bien mieux...
Admonition#
Une caractéristique remarquable de MkDocs avec Material sont ces admonitions : ce sont des boites colorées d'avertissements, pour des alertes, mises en garde et autres appartés, qui viennent compléter le flux normal de l'information sur une page web de documentation pour illustrer ou souligner un point particulier, une difficulté...
De base, il existe 12 styles de boites différentes définies par des noms de types. Si aucun de ces mots clés types n'est précisé, ou si le mot clé n'est pas reconnu, c'est le type note
qui sera utilisé par défaut.
Note
Un avertissement de type note
.
!!! note
Un avertissement de type `note`.
Abstract
Un avertissement de type abstract
(résumé), summary
(sommaire) ou tdlr
(too long ; didn't read).
!!! abstract
Un avertissement de type `abstract` (résumé), `summary` (sommaire) ou `tdlr` (too long ; didn't read).
Info
Un avertissement de type info
ou todo
(à faire).
!!! info
Un avertissement de type `info` ou `todo` (à faire).
Tip
Un avertissement de type tip
(astuce), hint
(indice), important
.
!!! tip
Un avertissement de type `tip` (astuce), `hint` (indice), `important`.
Success
Un avertissement de type success
, check
(vérifié) ou done
(terminé).
!!! success
Un avertissement de type `success`, `check` (vérifié) ou `done` (terminé).
Question
Un avertissement de type question
, help
(aide) ou faq
(Frequently Asked Questions)
!!! question
Un avertissement de type `question`, `help` (aide) ou `faq` (Frequently Asked Questions)
Attention
Un avertissement de type attention
, warning
, caution
(avertir).
!!! attention
Un avertissement de type `attention`, `warning`, `caution` (avertir).
Failure
Un avertissement de type failure
(échec), missing
(manquant), fail
(échouer).
!!! failure
Un avertissement de type `failure` (échec), `missing` (manquant), `fail` (échouer).
Danger
Un avertissement de type danger
ou error
.
!!! danger
Un avertissement de type `danger` ou `error`.
Bug
Un avertissement de type bug
.
!!! bug
Un avertissement de type `bug`.
Example
Un avertissement de type example
.
!!! example
Un avertissement de type `example`.
Quote
Un avertissement de type quote
(citation) ou cite
(citer).
!!! quote
Un avertissement de type `quote` (citation) ou `cite` (citer).
Pour la syntaxe, on commmence par trois points d'exclamation !!!
suivi d'une espace et du mot clé type de l'admonition qui s'affichera en titre par défaut.
Puis, après un retour à la ligne et une indentation de 4 espaces, on peut écrire en MarkDown le code du contenu de la boite d'avertissement.
Des titres personnalisés : ...
Après le type, il est possible d'ajouter un titre personnalisé entre guillemets ce qui va nous permettre au moins de franciser les titres de nos boites :
Exemple :
Un exemple de boite avec un titre personnalisé.
!!! example "Exemple :"
Un exemple de boite
avec un titre
personnalisé.
Un titre personalisé vide ""
permet de produire une boite d'avertissement sans barre de titre :
!!! example ""
Un exemple de boite sans titre.
Un exemple de boite sans titre.
Des boites déroulantes : ...
En remplaçant les trois points d'exclamation !!!
par trois points d'interrogation ???
on obtient une boite déroulante enroulée par défaut.
Exemple NF : ...
Un exemple de boite déroulante enroulée par défaut.
??? example "Exemple NF : ..."
Un exemple de boite déroulante
enroulée par défaut.
Pour qu'elle soit déroulée par défaut, il suffit d'ajouter un +
après les trois points d'interrogation ???
.
???+ example "Exemple NO : ..."
Un exemple de boite déroulante
déroulée par défaut.
Exemple NO : ...
Un exemple de boite déroulante déroulée par défaut.
Une boite d'avertissement déroulante possède toujours une barre de titre même avec un titre personnalisé vide !
Un exemple de boite déroulante sans titre mais avec une barre.
???+ example ""
Un exemple de boite déroulante
sans titre mais avec une barre.
Des boites "inline" : ...
Exemple :
Un exemple de boite s'alignant à gauche.
En indiquant inline
entre
le mot clé du type et le titre personnalisé,
cela modifie le comportement d'affichage de la boite
d'avertissement.
Elle s'aligne à gauche en parallèle du bloc de paragraphes qu'elle précède.
!!! example inline "Exemple :"
Un exemple de boite
s'alignant à gauche.
En indiquant `inline` entre
le mot clé du type et le titre personnalisé,
cela modifie le comportement d'affichage de la boite
d'avertissement.
Elle s'aligne à **gauche** en parallèle
du bloc de paragraphes qu'elle précède.
Exemple :
Un exemple de boite s'alignant à droite.
En indiquant inline end
entre
le mot clé du type et le titre personnalisé,
cela modifie le comportement d'affichage de la boite
d'avertissement.
Elle s'aligne à droite en parallèle du bloc de paragraphes qu'elle précède.
!!! example inline end "Exemple :"
Un exemple de boite
s'alignant à droite.
En indiquant `inline end` entre
le mot clé du type et le titre personnalisé,
cela modifie le comportement d'affichage de la boite
d'avertissement.
Elle s'aligne à **droite** en parallèle
du bloc de paragraphes qu'elle précède.
Des boites très personnalisées : ...
En attendant qu'il soit possible de choisir des icones personnalisés pour chaque type de boite d'avertissement, on peut déjà customiser ses propres types de boites d'avertissement, cf. la recette pour "Créer ses propres admonitions" de Franck CHAMBON, comme par exemple :
Adn
La boite très spéciale pour l'Atelier du numérique.
!!! adn
La boite très spéciale pour l'Atelier du numérique.
/*Ajout pour admonition spéciale adn */
:root {
--md-admonition-icon--adn: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 576 512"><path d="m290.2,256c51.2-33.4 164.8-119.4 164.8-224.6 0-11.3-9.1-20.4-20.4-20.4-11.3,0-20.4,9.1-20.4,20.4 0,93.3-122.2,175.6-158.2,197.9-36.1-22.2-158.2-104.4-158.2-197.9-1.42109e-14-11.3-9.1-20.4-20.4-20.4-11.3,0-20.4,9.1-20.4,20.4 0,105.2 113.6,191.2 164.8,224.6-51.3,33.4-164.9,119.4-164.9,224.6-7.10543e-15,11.3 9.1,20.4 20.4,20.4 11.3,0 20.4-9.1 20.4-20.4 0-93.3 122.2-175.6 158.2-197.9 36.1,22.2 158.2,104.4 158.2,197.9 0,11.3 9.1,20.4 20.4,20.4 11.3,0 20.4-9.1 20.4-20.4 0.2-105.2-113.4-191.2-164.7-224.6z"/><path d="m177,51.8h158c11.3,0 20.4-9.1 20.4-20.4 0-11.3-9.1-20.4-20.4-20.4h-158c-11.3,0-20.4,9.1-20.4,20.4 0,11.3 9.1,20.4 20.4,20.4z"/><path d="m211.7,113.3c-11.3,0-20.4,9.1-20.4,20.4 0,11.3 9.1,20.4 20.4,20.4h88.6c11.3,0 20.4-9.1 20.4-20.4 0-11.3-9.1-20.4-20.4-20.4h-88.6v1.42109e-14z"/><path d="m335,460.2h-158c-11.3,0-20.4,9.1-20.4,20.4 0,11.3 9.1,20.4 20.4,20.4h158c11.3,0 20.4-9.1 20.4-20.4 0-11.3-9.1-20.4-20.4-20.4z"/><path d="m300.3,398.7c11.3,0 20.4-9.1 20.4-20.4 0-11.3-9.1-20.4-20.4-20.4h-88.6c-11.3,0-20.4,9.1-20.4,20.4 0,11.3 9.1,20.4 20.4,20.4h88.6z"/></svg>')
}
.md-typeset .admonition.adn,
.md-typeset details.adn {
border-color: rgb(233, 32, 99);
}
.md-typeset .adn > .admonition-title,
.md-typeset .adn > summary {
background-color: rgba(233, 32, 99, 0.1);
border-color: rgb(233, 32, 99);
}
.md-typeset .adn > .admonition-title::before,
.md-typeset .adn > summary::before {
background-color: rgb(233, 32, 99);
-webkit-mask-image: var(--md-admonition-icon--adn);
mask-image: var(--md-admonition-icon--adn);
}
extra_css:
- stylesheets/extra.css
Info
Pour permettre les fonctionnalités des boites d'avertissement décrites ci-dessus,
il faut activer dans le fichier mkdocs.yml
les extensions :
markdown_extensions:
- admonition
- pymdownx.details
- pymdownx.superfences
Une explication en vidéo par Fred LELEU :
Onglet#
La syntaxe pour créer des onglets coulissants commence par trois signes d'égalité ===
suivi d'une espace et d'un titre écrit entre guillemets.
Puis, après un retour à la ligne et une indentation de 4 espaces, on peut écrire en MarkDown le code du contenu de cet onglet.
On quitte l'onglet en revenant à l'indentation de base. On peut alors en commencer un autre et ainsi de suite autant de fois que nécessaire.
On peut aussi imbriquer des onglets les uns dans les autres...
Exemple : ...
\(1+1=10\)
Calculer en base 2 !
=== "Justifier :"
$1+1=10$
=== "Indice :"
<img src="" width=50% />
=== "Réponse :"
_**Calculer en base 2 !**_ :wink:
Code MarkDown de cet exemple : ...
=== "Rendu :"
=== "Justifier :"
$1+1=10$
=== "Indice :"
<img src="" width=50% />
=== "Réponse :"
_**Calculer en base 2 !**_ :wink:
=== "Markdown :"
```md
=== "Justifier :"
$1+1=10$
=== "Indice :"
<img src="" width=50% />
=== "Réponse :"
_**Calculer en base 2 !**_ :wink:
```
Une explication en vidéo par Fred LELEU :
Codes#
Code inline#
Comme vu dans le Corps de texte,
on peut afficher dans le flux d'un paragraphe,
du code en caractères monospaces
en l'encadrant entre deux `
que l'on peut obtenir par la combinaison
de touches AltGr+è.
Mettre du code dans du code : ...
Si le codage renferme déjà une apostrophe inversée
( backtick, accent grave),
on peut précéder et terminer la zone de code de deux fois ce caractère.
Dans ce cas, MarkDown n’interprétera pas cette apostrophe inversée comme une balise.
Exemple : ``Ceci est du `code`.``
Exemple : Ceci est du `code`.
Activer la coloration syntaxique : ...
La coloration syntaxique s'applique aussi sur du code en ligne, par exemple, for lettre in "Bonjour" :
, s'obtient en écrivant en markdown `#!python3 for lettre in "Bonjour" :`
dans le flux du texte.
Après le premier `
, on place un shebang #!
(ou :::
) suivi d'un nom court désignant le langage utilisé. Aussi, ici on aurait pu se contenter du nom court py
qui correspont à python3
par défaut, ainsi le code `:::py for lettre in "Bonjour" :`
produit le même résultat : for lettre in "Bonjour" :
.
Info
Pour la coloration syntaxique du code en ligne, il faut activer dans le fichier mkdocs.yml
les extensions :
markdown_extensions:
- pymdownx.highlight
- pymdownx.inlinehilite
Bloc de texte brut#
Pour produire un bloc de texte brut,
il suffit de faire
un **saut de ligne**
et de précéder le code
d'une tabulation équivalente
à au moins **quatre espaces** :
Ceci est un bloc de texte brut ;
A l'intérieur de ce dernier,
tous les retours à la ligne,
sont considérés ;
Tous les espaces laissés vides sont conservés ;
L'indentation est donc respectée ;
De plus :
- aucun caractère de balisage **MarkDown**, <HTML> ou $LaTeX$ n'est interprété ;
+ ![image](url "info"){ heigt=300 align=left} ...
# tout le texte s'affiche en caractère monospace ;
On sort simplement de ce bloc de texte brut en revenant à une indentation inférieure à 4 espaces.
Pour produire un bloc de texte brut, il suffit de faire un saut de ligne et de précéder le code d'une tabulation équivalente à au moins quatre espaces :
Ceci est un bloc de texte brut ;
A l'intérieur de ce dernier,
tous les retours à la ligne,
sont considérés ;
Tous les espaces laissés vides sont conservés ;
L'indentation est donc respectée ;
De plus :
- aucun caractère de balisage **MarkDown**, <HTML> ou $LaTeX$ n'est interprété ;
+ ![image](url "info"){ heigt=300 align=left} ...
# tout le texte s'affiche en caractère monospace ;
On sort simplement de ce bloc de texte brut en revenant à une indentation inférieure à 4 espaces.
Une indentation ⩾ à 4 espaces après une ligne vide ⇒ génère du texte brut !
Bloc de code#
Coloré#
Une autre pratique pour produire des blocs de texte brut
consiste à encadrer les lignes de code
entre deux triplets d'apostrophes inversées
```
(backtick, accent grave) ;
Aussi, si on précise après le premier triplet le nom court du langage informatique correspondant au contenu des lignes de code, une coloration syntaxique idoine s'applique :
Exemple : ...
```
def ma_fonction(paramètres):
''' docstring '''
# bloc d'instructions (optionnel)
return valeur
```
def ma_fonction(paramètres):
''' docstring '''
# bloc d'instructions (optionnel)
return valeur
``` python
def ma_fonction(paramètres):
''' docstring '''
# bloc d'instructions (optionnel)
return valeur
```
def ma_fonction(paramètres):
''' docstring '''
# bloc d'instructions (optionnel)
return valeur
La liste des langages supportés est plutôt exhaustive. Aussi il est pratique d'utiliser la barre de recherche pour trouver un nom court correspondant au langage souhaité...
Numéroté, surligné#
Franck CHAMBON présente parfaitement les différentes options pour faire cela. Il s'appuie sur l'exemple de code utilisé dans la référence mkdocs-material à ce sujet :
Numérotation des lignes et marquage : ...
- Il suffit d'ajouter
linenums="1"
(ou un autre nombre) pour faire débuter la numérotation. - Pour marquer des lignes en particulier, on utilise
hl_lines="<tranches et numéros>"
Exemples : ...
Entrée
```python
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
Entrée
```python linenums="1"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
1 2 3 4 5 |
|
Entrée
```python linenums="42"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
42 43 44 45 46 |
|
Entrée
```python hl_lines="2"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
Entrée
```python linenums="1" hl_lines="2"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
1 2 3 4 5 |
|
Entrée
```python linenums="1" hl_lines="2 5"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
1 2 3 4 5 |
|
Entrée
```python linenums="1" hl_lines="2-4"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
1 2 3 4 5 |
|
Entrée
```python linenums="1" hl_lines="1 2 3-3 5-5"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
```
Rendu
1 2 3 4 5 |
|
Annoté ? ...
Cette fonctionnalité est pour l'instant exclusivement réservée aux insiders...
Info
Pour permettre les fonctionnalités des lignes et blocs de code décrites ci-dessus,
il faut activer dans le fichier mkdocs.yml
les extensions :
markdown_extensions:
- pymdownx.highlight
- pymdownx.inlinehilite
- pymdownx.superfences
- pymdownx.snippets
Intégré#
Ne pas copier/coller...
... le code ci-contre sans enlever l'espace laissé volontairement après le nom du fichier.
C'est un caractère d'échappement
qui évite l'intégration effective
du code contenu dans le fichier
mkdocs.yml
ici .
Pour afficher dans un bloc de code
le contenu du fichier mkdocs.yml
qui est situé à la racine du dépôt on écrirait :
```yaml
--8<-- "mkdocs.yml"
```
├── docs/
│ └── images/
│ │ └── undraw_Polaroid.svg
│ └── MarkDown-Mkdocs_Material.md
│ └── index.md
├── includes/
│ └── py/
│ └── exemple.py
└─ mkdocs.yml
Exemple 1 : un fichier MarkDown ...
Pour le fichier index.md
du dossier docs/
situé à la racine du dépôt :
```md
--8<-- "docs/index.md"
```
---
hide:
- navigation
- toc
---
Ceci est un tutoriel pour déployer un site web depuis un dépôt git
avec le framework material pour mkdocs en incluant, ou pas, des notebook jupyter...
[![building_websites](https://ericecmorlaix.github.io/adn-Tutoriel_site_web/images/undraw_building_websites_i78t.svg){: align=right width=53%}](https://undraw.co/illustrations "Illustration par unDraw"){target="_blank"}
???+ adncogs "Créer, déployer puis maintenir son site :"
1. [Premiers pas depuis un navigateur web](./PremiersPas) ;
2. [Puis sur PC avec Visual Studio Code](./PCW10-VSC) ;
3. [Et même sur un iPad en ligne de commande](./iPad.md) ;
![Bienvenue](https://ericecmorlaix.github.io/adn-Tutoriel_site_web/images/undraw_handcrafts_welcome.svg "Degemer Mat !"){width=20% .center }
???+ adncode "Coder pour générer ses pages web :"
1. [MarkDown Mkdocs-Material pour le contenu](./MarkDown-Mkdocs_Material.md) ;
2. [YAML pour la configuration](./Yaml.md) ;
3. [$\LaTeX$ pour les sciences](./LaTeX.md) ;
4. [Python pour les macros](./Python.md) ;
Exemple 2 : un fichier Python ...
Pour le fichier exemple.py
du dossier py/
situé dans le dossier includes
qui est aussi,
comme le dossier docs/
, à la racine du dépôt :
```py
--8<-- "includes/py/exemple.py"
```
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
Exemple 3 : un fichier SVG ...
Pour le fichier undraw_Polaroid.svg
du dossier images
situé le dossier docs/
:
```svg
--8<-- "docs/images/undraw_Polaroid.svg"
```
<svg id="b05a8b24-0cfe-4b22-93a9-3846e5c8b4da" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" width="541" height="606" viewBox="0 0 541 606"><path d="M847.04975,752.74227H352.02241a23.01224,23.01224,0,0,1-22.98633-22.98633V169.7286a23.01224,23.01224,0,0,1,22.98633-22.98633H847.04975a23.01223,23.01223,0,0,1,22.98633,22.98633V729.75594A23.01224,23.01224,0,0,1,847.04975,752.74227Z" transform="translate(-329.03608 -146.74227)" fill="#f2f2f2"/><path d="M822.15608,185.74227h-445.24a15.64143,15.64143,0,0,0-15.62,15.62v410.42a15.64143,15.64143,0,0,0,15.62,15.62h445.24a15.64142,15.64142,0,0,0,15.62-15.62v-410.42A15.64142,15.64142,0,0,0,822.15608,185.74227Z" transform="translate(-329.03608 -146.74227)" fill="#e92063"/><path d="M608.57468,374.35144c-4.32513-7.1534-9.45023-14.7911-17.47656-17.12689-9.295-2.705-18.84337,2.66857-26.94255,7.97116a785.1068,785.1068,0,0,0-69.86968,51.47911l.02443.27768q26.06891-1.79775,52.13774-3.59549c12.55653-.86592,25.54444-1.85127,36.64094-7.7913,4.21074-2.254,8.3153-5.26492,13.08677-5.47473,5.9281-.26064,11.097,3.87955,15.15908,8.20508,24.0284,25.587,30.98174,64.71558,57.93919,87.19565A855.50925,855.50925,0,0,0,608.57468,374.35144Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M756.27371,591.37542c-2.65715-3.35527-3.74288-4.14107-6.36393-7.52739q-32.01228-41.40317-60.17793-85.6033-19.13118-30.01909-36.365-61.19105-8.2047-14.81953-15.95956-29.87171-6.0176-11.67106-11.76659-23.48172c-1.09608-2.24892-2.16111-4.50817-3.22084-6.77259-2.49711-5.325-4.94777-10.67584-7.57917-15.92849-2.99845-5.98673-6.64843-12.263-12.15458-16.28521a16.58291,16.58291,0,0,0-8.6389-3.32424c-4.48227-.28952-8.61819,1.56132-12.506,3.58274a402.57534,402.57534,0,0,0-79.16143,54.58907,412.12253,412.12253,0,0,0-64.31385,71.39123c-.56849.81168-1.91271.0362-1.33892-.78063q3.389-4.79254,6.91222-9.48162A414.39962,414.39962,0,0,1,549.436,362.00731q10.29109-6.66917,20.96917-12.71282c3.58789-2.03177,7.19143-4.03769,10.85681-5.91951,3.59319-1.84566,7.40852-3.50522,11.51339-3.56725,13.9691-.21713,21.20193,15.60277,26.17014,26.24763q2.342,5.02513,4.74076,10.01928,9.06538,18.9606,18.82876,37.57489,6.02554,11.4927,12.31489,22.851,19.57307,35.36991,41.6074,69.30778c19.4596,29.96994,38.764,56.445,60.93246,84.4711C757.97993,591.05488,756.88915,592.16125,756.27371,591.37542Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M500.99918,391.7498c-.81159-.90473-1.61813-1.80946-2.435-2.7142-6.44169-7.12414-13.35366-14.16556-22.19955-18.2498a32.20737,32.20737,0,0,0-13.49351-3.12778,38.50755,38.50755,0,0,0-14.01025,3.05543c-2.10936.8427-4.17228,1.79912-6.20389,2.81757-2.32141,1.16841-4.60142,2.41437-6.87083,3.67066q-6.39018,3.5362-12.61452,7.38261-12.38468,7.654-23.99362,16.47649-6.018,4.57539-11.78754,9.45061-5.36631,4.52882-10.51551,9.30066c-.73409.67725-1.83017-.41876-1.09609-1.096.90474-.8427,1.81982-1.68022,2.73491-2.50739q3.87743-3.50522,7.87906-6.876,7.29706-6.15735,14.972-11.83907,11.93484-8.84055,24.69136-16.48166,6.37466-3.81539,12.92476-7.31026c1.31848-.7031,2.65236-1.39071,4.00163-2.04212a63.792,63.792,0,0,1,9.51258-3.87226,33.84064,33.84064,0,0,1,14.3672-1.41137,37.405,37.405,0,0,1,13.25571,4.58571c8.68534,4.85455,15.42162,12.36123,21.97716,19.687C502.75715,391.39308,501.66611,392.49427,500.99918,391.7498Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M678.9595,465.57479l20.81236-7.61222,10.3334-3.77949a105.67624,105.67624,0,0,1,10.20179-3.51362,16.09445,16.09445,0,0,1,9.23387.11765,21.28211,21.28211,0,0,1,7.20219,4.46461,58.449,58.449,0,0,1,5.90731,6.30858c2.24977,2.70372,4.46631,5.43579,6.6928,8.1587q13.78369,16.857,27.38714,33.86031,13.60313,17.003,27.02437,34.15055,13.45406,17.18943,26.723,34.52261,1.62548,2.12337,3.24817,4.24888c.59767.78282,1.94533.01107,1.33922-.7828q-13.36689-17.50749-26.92011-34.87165-13.58655-17.40566-27.36086-34.66367-13.774-17.25766-27.73423-34.36566-3.4779-4.26211-6.96729-8.51485c-1.96228-2.39156-3.90244-4.8089-6.05473-7.03486-3.95068-4.08591-8.88656-7.69676-14.79487-7.79473-3.47378-.0576-6.83564,1.04471-10.06315,2.21231-3.47938,1.25872-6.95042,2.541-10.42536,3.812l-20.9579,7.66544-5.23947,1.91637c-.92981.34008-.52815,1.83954.41231,1.49557Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M473.62576,379.75015a33.60017,33.60017,0,0,0-33.83986,2.42A482.65361,482.65361,0,0,1,494.698,394.98639C487.20731,390.59664,481.34778,383.7189,473.62576,379.75015Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M439.68181,382.15146l-2.0361,1.655c.68871-.57924,1.40469-1.12233,2.14019-1.63626C439.75116,382.16417,439.71655,382.15745,439.68181,382.15146Z" transform="translate(-329.03608 -146.74227)" fill="#f2f2f2"/><path d="M735.95944,465.65083c-2.04871-2.49382-4.26372-5.105-7.32808-6.11793l-2.861.11283a324.5172,324.5172,0,0,0,86.43508,98.81564Q774.08247,512.05611,735.95944,465.65083Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><g opacity="0.17"><path d="M791.79345,323.39222c5.76935-2.51553-5.93086-3.9799-19.20533-4.46137s-29.33268-.45483-37.8158-1.82429c-8.2044-1.32446-7.5999-3.67944-8.29-5.81314s-3.84423-4.32149-16.64635-4.79579c-15.95307-.591-42.26067,1.684-54.30349.31817-11.23819-1.2746-4.558-5.27276-20.94516-5.42579-9.3576-.08738-21.41277,1.23075-31.825,1.54885a116.01452,116.01452,0,0,1-22.08215-1.15126c-5.075-.83149-8.60986-1.88563-14.32157-2.62006-14.99567-1.92821-44.33435-1.28008-70.5202,1.19119s-48.63194,6.52118-61.29082,10.53243-16.15629,7.96063-13.20756,11.3097c1.88293,2.13857,6.70129,4.13827,18.38945,4.99762,21.86194,1.60736,60.78519-1.15935,83.37576.303,12.5907.81506,18.17647,2.83584,29.22349,3.94158,11.86819,1.18794,29.24216,1.25091,46.31211,1.22273,35.54177-.05869,71.99263-.42383,109.16139-1.09351,15.52474-.27972,31.79162-.64338,48.31132-1.97637s33.36908-3.90493,36.85433-6.316" transform="translate(-329.03608 -146.74227)" fill="#fff"/></g><circle cx="217.0152" cy="124.42378" r="2.99187" fill="#fff"/><circle cx="290.23466" cy="91.99777" r="1.79512" fill="#fff"/><circle cx="191.23466" cy="202.99777" r="1.79512" fill="#fff"/><circle cx="397.23154" cy="119.40752" r="1.79512" fill="#fff"/><circle cx="278.23154" cy="170.40752" r="1.79512" fill="#fff"/><circle cx="327.23154" cy="138.40752" r="1.79512" fill="#fff"/><circle cx="417.93247" cy="234.36521" r="1.79512" fill="#fff"/><circle cx="73.93247" cy="219.36521" r="1.79512" fill="#fff"/><path d="M837.77607,576.85225v34.93a15.64142,15.64142,0,0,1-15.62,15.62h-445.24a15.64143,15.64143,0,0,1-15.62-15.62v-43.64a264.22453,264.22453,0,0,1,70.01-7.48c56.9,1.24,112.47,16.43,168.84,24.29a659.89327,659.89327,0,0,0,199.88-2.75C812.48609,580.11226,825.1761,577.67226,837.77607,576.85225Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M686.761,417.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C692.95023,425.15035,689.03457,422.06505,686.761,417.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M540.761,529.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C546.95023,537.15035,543.03457,534.06505,540.761,529.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M720.761,506.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C726.95023,514.15035,723.03457,511.06505,720.761,506.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M452.16255,264.0201A31.01709,31.01709,0,1,1,483.17964,233.003,31.052,31.052,0,0,1,452.16255,264.0201Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M545.59839,231.41249c-8.0763-8.47227-17.45607-16.20121-28.56-20.28545a45.90466,45.90466,0,0,0-9.56581-2.40387c-.02626-.00362-.05113.00171-.07725-.0004a1.40837,1.40837,0,0,0-.16135-.03167,36.82309,36.82309,0,0,0-13.66765.82514,37.76206,37.76206,0,0,0-6.36383,2.21691,55.65007,55.65007,0,0,0-5.97143,3.38416A38.83959,38.83959,0,0,1,468.03554,220.04a44.3928,44.3928,0,0,1-7.08718.69559,17.11875,17.11875,0,0,0-5.96219.85823,14.31053,14.31053,0,0,0-8.71529,9.43667.92793.92793,0,0,0,.41248,1.01363c.52865.37862,1.044.80819,1.59944,1.1455a4.98957,4.98957,0,0,0,1.56233.4261q1.32459.27951,2.65255.54268,4.8922.96933,9.82507,1.71609,9.98148,1.511,20.07078,2.12875a223.4829,223.4829,0,0,0,40.3964-1.21409,224.25471,224.25471,0,0,0,22.41238-3.87651A.90587.90587,0,0,0,545.59839,231.41249Z" transform="translate(-329.03608 -146.74227)" fill="#f0f0f0"/><path d="M453.61072,251.81649a45.90466,45.90466,0,0,0-9.56581-2.40387c-.02626-.00361-.05113.00172-.07725-.0004a1.40835,1.40835,0,0,0-.16135-.03166,36.82309,36.82309,0,0,0-13.66765.82514,37.76118,37.76118,0,0,0-6.36383,2.21691,55.65281,55.65281,0,0,0-5.97144,3.38415,38.83947,38.83947,0,0,1-13.19553,4.92271,44.39166,44.39166,0,0,1-7.08718.6956,17.11851,17.11851,0,0,0-5.96219.85823A14.31052,14.31052,0,0,0,382.8432,271.72a.92793.92793,0,0,0,.41248,1.01363c.52865.37862,1.044.80819,1.59944,1.14551a4.9901,4.9901,0,0,0,1.56233.4261q1.32459.27949,2.65255.54268,4.89221.96933,9.82507,1.71609,9.98148,1.511,20.07078,2.12875a223.482,223.482,0,0,0,40.3964-1.2141,224.25181,224.25181,0,0,0,22.41238-3.8765.90588.90588,0,0,0,.39608-1.50018C474.09441,263.62967,464.71464,255.90073,453.61072,251.81649Z" transform="translate(-329.03608 -146.74227)" fill="#f0f0f0"/><path d="M592.03608,681.74227h-225a6,6,0,0,1,0-12h225a6,6,0,1,1,0,12Z" transform="translate(-329.03608 -146.74227)" fill="#ccc"/><path d="M479.03608,715.24227h-112a6,6,0,0,1,0-12h112a6,6,0,1,1,0,12Z" transform="translate(-329.03608 -146.74227)" fill="#ccc"/><polygon points="107.375 384.038 124.578 370.977 132.963 379.362 104.938 398.541 107.375 384.038" fill="#2f2e41"/><path d="M420.36583,566.74387H361.51722l2.064-6.68758h0c12.79222-4.63087,5.60682-14.58464,17.77517-20.66882,29.7631-14.88155,41.28561-59.28965,36.92732-76.84429l19.50438-.82469S464.72374,538.21174,420.36583,566.74387Z" transform="translate(-329.03608 -146.74227)" fill="#2f2e41"/><path d="M470.60568,535.3075a9.89147,9.89147,0,0,1-12.78172.23913l-.03826-.03142-.00131-.04919a9.47684,9.47684,0,0,0-.37995-2.4188,6.77026,6.77026,0,0,1-.24584,1.67423l-.04929.1836-.13219-.13647c-.11417-.11773-.22466-.23731-.32842-.35529a9.97468,9.97468,0,0,1-1.51926-2.30058,29.07888,29.07888,0,0,0-8.06828-10.05664,14.118,14.118,0,0,1-1.69263-1.62867,13.95425,13.95425,0,0,1,17.52315-21.25934l.08719.051-.04528.09025a7.26871,7.26871,0,0,1-1.29692,1.87076,9.47928,9.47928,0,0,0,1.9974-1.44308l.06337-.05975.0718.04951a14.01337,14.01337,0,0,1,2.55182,2.27146l.08134.09326a6.2294,6.2294,0,0,0,4.6128,2.12867,9.88837,9.88837,0,0,1,9.57517,11.58491l-.0112.06532-.06355.01925a8.48535,8.48535,0,0,1-3.45588.43121,9.64019,9.64019,0,0,0,3.07823.771l.13713.01088-.04353.13058a9.8818,9.8818,0,0,1-2.852,4.30008l-.03754.03285-.03986.03489a9.7103,9.7103,0,0,0-3.35461,6.74A9.964,9.964,0,0,1,470.60568,535.3075Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M472.40585,532.12862a9.86349,9.86349,0,0,1-.11121,1.06328,9.99679,9.99679,0,0,0,1.60714-4.95271c.01311-.27.04146-.539.07947-.80679A9.38181,9.38181,0,0,0,472.40585,532.12862Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M475.51806,520.10833a9.62507,9.62507,0,0,0,2.45985.6955,9.89773,9.89773,0,0,0,.90133-1.0997A8.38739,8.38739,0,0,1,475.51806,520.10833Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M479.14311,516.86068a9.949,9.949,0,0,1-.07038,2.5661,9.83448,9.83448,0,0,0,1.11307-2.29544l.04354-.13058-.13714-.01088A9.55592,9.55592,0,0,1,479.14311,516.86068Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M478.228,507.47444a9.91161,9.91161,0,0,0-7.25857-3.35623,6.22938,6.22938,0,0,1-4.61281-2.12868l-.08134-.09325a14.01337,14.01337,0,0,0-2.55182-2.27146l-.0718-.04951-.06336.05975a9.47874,9.47874,0,0,1-1.99742,1.44307,7.269,7.269,0,0,0,1.297-1.87076l.04525-.09024-.08718-.051a13.94385,13.94385,0,0,0-20.659,9.02719,13.94642,13.94642,0,0,1,19.163-5.13776l.08718.051-.04525.09024a7.26926,7.26926,0,0,1-1.297,1.87076,9.47868,9.47868,0,0,0,1.99741-1.44307l.06337-.05975.0718.04951a14.01337,14.01337,0,0,1,2.55182,2.27146l.08133.09326a6.22944,6.22944,0,0,0,4.61282,2.12867,9.89007,9.89007,0,0,1,9.565,8.12834,11.98677,11.98677,0,0,0,1.43129-.34829l.06355-.01925.01125-.06532A9.85036,9.85036,0,0,0,478.228,507.47444Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M499.04886,466.75383a31.84958,31.84958,0,0,1-26.603,31.41149l-.15732.02566-.12171-.10142a30.51655,30.51655,0,0,0-6.656-4.22513,21.8005,21.8005,0,0,1,3.52508,4.15475l.339.50961-.611.0294c-.52742.02566-1.05152.0385-1.55741.0385a32.118,32.118,0,0,1-8.793-1.21919,93.63086,93.63086,0,0,0-41.47214-1.87907,45.458,45.458,0,0,1-7.53721.62884,44.93133,44.93133,0,0,1-14.1355-87.57594l.30883-.10225.12192.30138a23.40468,23.40468,0,0,1,1.765,7.11391,30.52291,30.52291,0,0,0,.75863-7.898l-.00973-.28026.2724-.06831a45.12252,45.12252,0,0,1,10.91843-1.33924l.39846.00165a20.05806,20.05806,0,0,0,14.956-6.62582,31.83962,31.83962,0,0,1,48.3716,1.48579l.13413.166-.08859.19457a27.32206,27.32206,0,0,1-6.30664,9.27243,31.04045,31.04045,0,0,0,8.4101-5.80282l.31794-.30842.22313.38293a31.8183,31.8183,0,0,1,4.33152,16.03983l-.00041.16063c-.00042.05672-.00042.11385-.00042.17056a31.26636,31.26636,0,0,0,9.1619,22.44376A32.08311,32.08311,0,0,1,499.04886,466.75383Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><g opacity="0.15"><path d="M460.11959,391.50282a22.49407,22.49407,0,0,1-4.012,4.92175,30.96211,30.96211,0,0,0,6.26856-3.91791Q461.26814,391.96086,460.11959,391.50282Z" transform="translate(-329.03608 -146.74227)"/><path d="M478.55133,429.51105A31.97,31.97,0,0,1,483.13,435.089a32.54708,32.54708,0,0,1-2.97907-13.6731c0-.05672,0-.11385.0004-.17055l.00041-.16063a31.81856,31.81856,0,0,0-4.3315-16.03983l-.22314-.38294-.318.30841a31.112,31.112,0,0,1-5.80764,4.42232A31.01389,31.01389,0,0,0,478.55133,429.51105Z" transform="translate(-329.03608 -146.74227)"/><path d="M469.39025,406.7361l-.0004.16063c-.00041.05671-.00041.11384-.00041.17056,0,.31256.00566.62434.01439.93563a33.16272,33.16272,0,0,0,3.77185-6.50215l.08857-.19458-.13411-.166a32.10042,32.10042,0,0,0-5.76052-5.57135A31.89066,31.89066,0,0,1,469.39025,406.7361Z" transform="translate(-329.03608 -146.74227)"/><path d="M489.31279,443.85966a28.78932,28.78932,0,0,1-4.05843-4.93763,31.8105,31.8105,0,0,1-23.57,44.89467l-.15732.02568-.1217-.10143a30.5172,30.5172,0,0,0-6.65606-4.22512,21.79991,21.79991,0,0,1,3.52506,4.15473l.33907.50963-.611.02938c-.52745.02568-1.05154.03851-1.55741.03851a32.11821,32.11821,0,0,1-8.793-1.21919,93.631,93.631,0,0,0-41.47214-1.87907,45.45764,45.45764,0,0,1-7.53719.62883,44.7262,44.7262,0,0,1-29.84116-11.37979,44.97143,44.97143,0,0,0,40.60261,25.72841,45.45767,45.45767,0,0,0,7.5372-.62884,93.631,93.631,0,0,1,41.47214,1.87907,32.11819,32.11819,0,0,0,8.793,1.21919c.50588,0,1.03-.01283,1.55742-.03851l.611-.02938-.33907-.50962a21.79968,21.79968,0,0,0-3.52506-4.15474,30.5169,30.5169,0,0,1,6.656,4.22512l.12171.10143.15731-.02568a31.82584,31.82584,0,0,0,16.867-54.30565Z" transform="translate(-329.03608 -146.74227)"/></g></svg>
Info
Pour permettre cette fonctionnalité d'intégration
de contenu externe
décrite ci-dessus,
il faut activer dans le fichier mkdocs.yml
l'extension :
markdown_extensions:
- pymdownx.snippets
Inclusion#
Quid : si on intègre le contenu d'un fichier en dehors d'un bloc de code ?
--8<-- "docs/index.md"
hide: - navigation - toc
Ceci est un tutoriel pour déployer un site web depuis un dépôt git avec le framework material pour mkdocs en incluant, ou pas, des notebook jupyter...
Créer, déployer puis maintenir son site :
Coder pour générer ses pages web :
--8<-- "includes/py/exemple.py"
def tri_bulles(items): for i in range(len(items)): for j in range(len(items) - 1 - i): if items[j] > items[j + 1]: items[j], items[j + 1] = items[j + 1], items[j]
--8<-- "docs/images/undraw_Polaroid.svg"
Fichier .md
#
On observe que le code MarkDown contenu dans le fichier index.md
s'affiche bien, hormis son en tête de métadonnées...
On a là une solution pour inclure du contenu externe codé en MarkDown pour développer une longue page web en la décomposant en sous-parties.
Exemple avec le début du code qui génère cette page : ...
# MarkDown Mkdocs-Material pour le contenu
## Introduction :
=== "Rendu MarkDown"
--8<-- "includes/md/introductionM.md"
=== "MarkDown"
```md
--8<-- "includes/md/introductionM.md"
```
=== "HTML"
```html
--8<-- "includes/md/introductionH.md"
```
=== "Rendu HTML :"
--8<-- "includes/md/introductionH.md"
***
## Titres :
--8<-- "includes/md/titres.md"
***
## Corps de texte :
--8<-- "includes/md/texte.md"
***
## Lien :
--8<-- "includes/md/lien.md"
***
Il est alors simple de répéter plusieurs fois un même bout de code dans une ou plusieurs pages différentes à partir d'une seule et même source.
C'est le cas ici du contenu du fichier introductionM.md
qui est appelé deux fois dans la partie ## Introduction :
,
et également dans le fichier lien.md
,
qui est lui même intégré plus loin dans la partie ## Lien :
.
Au total, on retrouve trois fois le contenu du paragraphe d'introduction MarkDown dans cette page et s'il faut y apporter une modification, il suffira d'agir dans son unique fichier source pour la répercuter partout...
Ce mécanisme d'inclusion d'extraits de code MarkDown est permis par l'extension Snippets.
La syntaxe --8<--
représente une paire de ciseaux en art ASCII.
Il est aussi possible d'inclure plusieurs fichiers d'affilée
en ajoutant selon le besoin des sauts de lignes et des indentations,
un point virgule suivi d'une espace pour ignorer un fichier...
Comme par exemple ainsi : ...
--8<--
includes/md/loremIpsum.md
includes/md/totoAlerte.md
includes/md/loremIpsum.md
includes/md/loremIpsum.md
; includes/md/loremIpsum.md
includes/md/loremIpsum.md
includes/md/loremIpsum.md
includes/md/loremIpsum.md
--8<--
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
???+ warning inline end "<a id='toto'></a>ATTENTION !"
**Toto** est dans la place...
*Ceci est une mise en garde,
vous voilà prévenu !!*
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac causa maxime homines admirentur et repredant meum consilium, cum ego idem antea multa derim, que magis ad hominis dignitatem quam ad rei publicae necessitatem pertinerent ?
ATTENTION !
Toto est dans la place...
Ceci est une mise en garde, vous voilà prévenu !!
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac causa maxime homines admirentur et repredant meum consilium, cum ego idem antea multa derim, que magis ad hominis dignitatem quam ad rei publicae necessitatem pertinerent ? Sed quid est quod in hac causa maxime homines admirentur et repredant meum consilium, cum ego idem antea multa derim, que magis ad hominis dignitatem quam ad rei publicae necessitatem pertinerent ?
Sed quid est quod in hac
causa maxime homines
admirentur et repredant
meum consilium, cum ego
idem antea multa derim,
que magis ad hominis
dignitatem quam ad rei
publicae necessitatem
pertinerent ?
Sed quid est quod in hac causa maxime homines admirentur et repredant meum consilium, cum ego idem antea multa derim, que magis ad hominis dignitatem quam ad rei publicae necessitatem pertinerent ?
Remarque :
Snippets concatène (agrège) tout le code contenu dans les fichiers à inclure, il peut donc être nécessaire d'insérer des sauts de lignes et/ou des indentations entre les extraits inclus.
Le fonctionnement de Snippets est-il récursif ?
Si comme moi vous êtes joueur, vous brulez d'envie de l'expérimenter pour le vérifier par vous même... , sinon :
La réponse se trouve là…
Oui, c'est récursif au sens ou un fichier_a.md
peut inclure un fichier_b.md
qui lui même
inclut un autre fichier_c.md
et ainsi de suite...
Non, ce n'est pas vraiment récursif car le fichier_b.md
ne peut pas s'inclure lui même, ni être inclus dans le fichier_c
qu'il inclut déjà.
Dès que Snippets rencontre une nouvelle fois un même fichier
dans la pile d'appels, le processus d'inclusion s'arrête par sécurité
pour éviter une boucle infinie...
Un fichier unique de références hypertextes et d'abréviations : ...
L'extension Snippets permet ainsi de créer facilement un fichier commun de références pour regrouper toutes les adresses de liens des différentes pages d'un site.
De plus, en l'associant avec l'extension
md abbr
qui sert à définir des abréviations et qu'il faut rajouter dans le fichier mkdocs.yml
:
markdown_extensions:
- abbr
- pymdownx.snippets
<!-- Liste d'abréviations -->
*[HTML]: Hyper Text Markup Language
<!-- Liste d'URL référencées pour liens hypertextes -->
[W3C]: https://www.w3.org/Consortium/ "World Wide Web Consortium"
La spécification HTML est maintenue par le [W3C]{target=_blank}.
--8<-- "includes/md/abr_ref-exemple.md"
La spécification HTML est maintenue par le W3C.
Autres fichiers#
On observe que le contenu du fichier .py
n'est pas bien interprété
car son indentation n'est pas respecté.
Ce genre de contenu ne sera correctement affiché que dans un bloc de code
encadré entre des ```
et en précisant le langage
si on souhaite la coloration syntaxique.
Pour un affichage plus basique en texte brut,
il suffit d'indenter de 4 espaces à gauche avant les ciseaux --8<--
:
--8<-- "includes/py/exemple.py"
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
def tri_bulles(items):
for i in range(len(items)):
for j in range(len(items) - 1 - i):
if items[j] > items[j + 1]:
items[j], items[j + 1] = items[j + 1], items[j]
En revanche le code du fichier .svg
est bien interprété.
Voici donc une autre façon d'intégrer une image SVG mais sans la gestion ici de la taille d'affichage :
<figure markdown>
--8<-- "docs/images/undraw_Polaroid.svg"
<figcaption markdown>
Un Polaroïd selon [unDraw]{target="_blank"}
</figcaption>
</figure>
<figure markdown>
<svg id="b05a8b24-0cfe-4b22-93a9-3846e5c8b4da" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" width="541" height="606" viewBox="0 0 541 606"><path d="M847.04975,752.74227H352.02241a23.01224,23.01224,0,0,1-22.98633-22.98633V169.7286a23.01224,23.01224,0,0,1,22.98633-22.98633H847.04975a23.01223,23.01223,0,0,1,22.98633,22.98633V729.75594A23.01224,23.01224,0,0,1,847.04975,752.74227Z" transform="translate(-329.03608 -146.74227)" fill="#f2f2f2"/><path d="M822.15608,185.74227h-445.24a15.64143,15.64143,0,0,0-15.62,15.62v410.42a15.64143,15.64143,0,0,0,15.62,15.62h445.24a15.64142,15.64142,0,0,0,15.62-15.62v-410.42A15.64142,15.64142,0,0,0,822.15608,185.74227Z" transform="translate(-329.03608 -146.74227)" fill="#e92063"/><path d="M608.57468,374.35144c-4.32513-7.1534-9.45023-14.7911-17.47656-17.12689-9.295-2.705-18.84337,2.66857-26.94255,7.97116a785.1068,785.1068,0,0,0-69.86968,51.47911l.02443.27768q26.06891-1.79775,52.13774-3.59549c12.55653-.86592,25.54444-1.85127,36.64094-7.7913,4.21074-2.254,8.3153-5.26492,13.08677-5.47473,5.9281-.26064,11.097,3.87955,15.15908,8.20508,24.0284,25.587,30.98174,64.71558,57.93919,87.19565A855.50925,855.50925,0,0,0,608.57468,374.35144Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M756.27371,591.37542c-2.65715-3.35527-3.74288-4.14107-6.36393-7.52739q-32.01228-41.40317-60.17793-85.6033-19.13118-30.01909-36.365-61.19105-8.2047-14.81953-15.95956-29.87171-6.0176-11.67106-11.76659-23.48172c-1.09608-2.24892-2.16111-4.50817-3.22084-6.77259-2.49711-5.325-4.94777-10.67584-7.57917-15.92849-2.99845-5.98673-6.64843-12.263-12.15458-16.28521a16.58291,16.58291,0,0,0-8.6389-3.32424c-4.48227-.28952-8.61819,1.56132-12.506,3.58274a402.57534,402.57534,0,0,0-79.16143,54.58907,412.12253,412.12253,0,0,0-64.31385,71.39123c-.56849.81168-1.91271.0362-1.33892-.78063q3.389-4.79254,6.91222-9.48162A414.39962,414.39962,0,0,1,549.436,362.00731q10.29109-6.66917,20.96917-12.71282c3.58789-2.03177,7.19143-4.03769,10.85681-5.91951,3.59319-1.84566,7.40852-3.50522,11.51339-3.56725,13.9691-.21713,21.20193,15.60277,26.17014,26.24763q2.342,5.02513,4.74076,10.01928,9.06538,18.9606,18.82876,37.57489,6.02554,11.4927,12.31489,22.851,19.57307,35.36991,41.6074,69.30778c19.4596,29.96994,38.764,56.445,60.93246,84.4711C757.97993,591.05488,756.88915,592.16125,756.27371,591.37542Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M500.99918,391.7498c-.81159-.90473-1.61813-1.80946-2.435-2.7142-6.44169-7.12414-13.35366-14.16556-22.19955-18.2498a32.20737,32.20737,0,0,0-13.49351-3.12778,38.50755,38.50755,0,0,0-14.01025,3.05543c-2.10936.8427-4.17228,1.79912-6.20389,2.81757-2.32141,1.16841-4.60142,2.41437-6.87083,3.67066q-6.39018,3.5362-12.61452,7.38261-12.38468,7.654-23.99362,16.47649-6.018,4.57539-11.78754,9.45061-5.36631,4.52882-10.51551,9.30066c-.73409.67725-1.83017-.41876-1.09609-1.096.90474-.8427,1.81982-1.68022,2.73491-2.50739q3.87743-3.50522,7.87906-6.876,7.29706-6.15735,14.972-11.83907,11.93484-8.84055,24.69136-16.48166,6.37466-3.81539,12.92476-7.31026c1.31848-.7031,2.65236-1.39071,4.00163-2.04212a63.792,63.792,0,0,1,9.51258-3.87226,33.84064,33.84064,0,0,1,14.3672-1.41137,37.405,37.405,0,0,1,13.25571,4.58571c8.68534,4.85455,15.42162,12.36123,21.97716,19.687C502.75715,391.39308,501.66611,392.49427,500.99918,391.7498Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M678.9595,465.57479l20.81236-7.61222,10.3334-3.77949a105.67624,105.67624,0,0,1,10.20179-3.51362,16.09445,16.09445,0,0,1,9.23387.11765,21.28211,21.28211,0,0,1,7.20219,4.46461,58.449,58.449,0,0,1,5.90731,6.30858c2.24977,2.70372,4.46631,5.43579,6.6928,8.1587q13.78369,16.857,27.38714,33.86031,13.60313,17.003,27.02437,34.15055,13.45406,17.18943,26.723,34.52261,1.62548,2.12337,3.24817,4.24888c.59767.78282,1.94533.01107,1.33922-.7828q-13.36689-17.50749-26.92011-34.87165-13.58655-17.40566-27.36086-34.66367-13.774-17.25766-27.73423-34.36566-3.4779-4.26211-6.96729-8.51485c-1.96228-2.39156-3.90244-4.8089-6.05473-7.03486-3.95068-4.08591-8.88656-7.69676-14.79487-7.79473-3.47378-.0576-6.83564,1.04471-10.06315,2.21231-3.47938,1.25872-6.95042,2.541-10.42536,3.812l-20.9579,7.66544-5.23947,1.91637c-.92981.34008-.52815,1.83954.41231,1.49557Z" transform="translate(-329.03608 -146.74227)" fill="#e4e4e4"/><path d="M473.62576,379.75015a33.60017,33.60017,0,0,0-33.83986,2.42A482.65361,482.65361,0,0,1,494.698,394.98639C487.20731,390.59664,481.34778,383.7189,473.62576,379.75015Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M439.68181,382.15146l-2.0361,1.655c.68871-.57924,1.40469-1.12233,2.14019-1.63626C439.75116,382.16417,439.71655,382.15745,439.68181,382.15146Z" transform="translate(-329.03608 -146.74227)" fill="#f2f2f2"/><path d="M735.95944,465.65083c-2.04871-2.49382-4.26372-5.105-7.32808-6.11793l-2.861.11283a324.5172,324.5172,0,0,0,86.43508,98.81564Q774.08247,512.05611,735.95944,465.65083Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><g opacity="0.17"><path d="M791.79345,323.39222c5.76935-2.51553-5.93086-3.9799-19.20533-4.46137s-29.33268-.45483-37.8158-1.82429c-8.2044-1.32446-7.5999-3.67944-8.29-5.81314s-3.84423-4.32149-16.64635-4.79579c-15.95307-.591-42.26067,1.684-54.30349.31817-11.23819-1.2746-4.558-5.27276-20.94516-5.42579-9.3576-.08738-21.41277,1.23075-31.825,1.54885a116.01452,116.01452,0,0,1-22.08215-1.15126c-5.075-.83149-8.60986-1.88563-14.32157-2.62006-14.99567-1.92821-44.33435-1.28008-70.5202,1.19119s-48.63194,6.52118-61.29082,10.53243-16.15629,7.96063-13.20756,11.3097c1.88293,2.13857,6.70129,4.13827,18.38945,4.99762,21.86194,1.60736,60.78519-1.15935,83.37576.303,12.5907.81506,18.17647,2.83584,29.22349,3.94158,11.86819,1.18794,29.24216,1.25091,46.31211,1.22273,35.54177-.05869,71.99263-.42383,109.16139-1.09351,15.52474-.27972,31.79162-.64338,48.31132-1.97637s33.36908-3.90493,36.85433-6.316" transform="translate(-329.03608 -146.74227)" fill="#fff"/></g><circle cx="217.0152" cy="124.42378" r="2.99187" fill="#fff"/><circle cx="290.23466" cy="91.99777" r="1.79512" fill="#fff"/><circle cx="191.23466" cy="202.99777" r="1.79512" fill="#fff"/><circle cx="397.23154" cy="119.40752" r="1.79512" fill="#fff"/><circle cx="278.23154" cy="170.40752" r="1.79512" fill="#fff"/><circle cx="327.23154" cy="138.40752" r="1.79512" fill="#fff"/><circle cx="417.93247" cy="234.36521" r="1.79512" fill="#fff"/><circle cx="73.93247" cy="219.36521" r="1.79512" fill="#fff"/><path d="M837.77607,576.85225v34.93a15.64142,15.64142,0,0,1-15.62,15.62h-445.24a15.64143,15.64143,0,0,1-15.62-15.62v-43.64a264.22453,264.22453,0,0,1,70.01-7.48c56.9,1.24,112.47,16.43,168.84,24.29a659.89327,659.89327,0,0,0,199.88-2.75C812.48609,580.11226,825.1761,577.67226,837.77607,576.85225Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M686.761,417.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C692.95023,425.15035,689.03457,422.06505,686.761,417.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M540.761,529.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C546.95023,537.15035,543.03457,534.06505,540.761,529.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M720.761,506.85547c-2.27357-4.20958-2.591-9.7268.20064-13.61217a22.04318,22.04318,0,0,0,8.78119,12.32609c1.65858,1.12925,3.62091,2.21254,4.1883,4.13717a4.92756,4.92756,0,0,1-.51378,3.61684,14.63438,14.63438,0,0,1-2.27087,2.96491l-.08038.30113C726.95023,514.15035,723.03457,511.06505,720.761,506.85547Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M452.16255,264.0201A31.01709,31.01709,0,1,1,483.17964,233.003,31.052,31.052,0,0,1,452.16255,264.0201Z" transform="translate(-329.03608 -146.74227)" fill="#fff"/><path d="M545.59839,231.41249c-8.0763-8.47227-17.45607-16.20121-28.56-20.28545a45.90466,45.90466,0,0,0-9.56581-2.40387c-.02626-.00362-.05113.00171-.07725-.0004a1.40837,1.40837,0,0,0-.16135-.03167,36.82309,36.82309,0,0,0-13.66765.82514,37.76206,37.76206,0,0,0-6.36383,2.21691,55.65007,55.65007,0,0,0-5.97143,3.38416A38.83959,38.83959,0,0,1,468.03554,220.04a44.3928,44.3928,0,0,1-7.08718.69559,17.11875,17.11875,0,0,0-5.96219.85823,14.31053,14.31053,0,0,0-8.71529,9.43667.92793.92793,0,0,0,.41248,1.01363c.52865.37862,1.044.80819,1.59944,1.1455a4.98957,4.98957,0,0,0,1.56233.4261q1.32459.27951,2.65255.54268,4.8922.96933,9.82507,1.71609,9.98148,1.511,20.07078,2.12875a223.4829,223.4829,0,0,0,40.3964-1.21409,224.25471,224.25471,0,0,0,22.41238-3.87651A.90587.90587,0,0,0,545.59839,231.41249Z" transform="translate(-329.03608 -146.74227)" fill="#f0f0f0"/><path d="M453.61072,251.81649a45.90466,45.90466,0,0,0-9.56581-2.40387c-.02626-.00361-.05113.00172-.07725-.0004a1.40835,1.40835,0,0,0-.16135-.03166,36.82309,36.82309,0,0,0-13.66765.82514,37.76118,37.76118,0,0,0-6.36383,2.21691,55.65281,55.65281,0,0,0-5.97144,3.38415,38.83947,38.83947,0,0,1-13.19553,4.92271,44.39166,44.39166,0,0,1-7.08718.6956,17.11851,17.11851,0,0,0-5.96219.85823A14.31052,14.31052,0,0,0,382.8432,271.72a.92793.92793,0,0,0,.41248,1.01363c.52865.37862,1.044.80819,1.59944,1.14551a4.9901,4.9901,0,0,0,1.56233.4261q1.32459.27949,2.65255.54268,4.89221.96933,9.82507,1.71609,9.98148,1.511,20.07078,2.12875a223.482,223.482,0,0,0,40.3964-1.2141,224.25181,224.25181,0,0,0,22.41238-3.8765.90588.90588,0,0,0,.39608-1.50018C474.09441,263.62967,464.71464,255.90073,453.61072,251.81649Z" transform="translate(-329.03608 -146.74227)" fill="#f0f0f0"/><path d="M592.03608,681.74227h-225a6,6,0,0,1,0-12h225a6,6,0,1,1,0,12Z" transform="translate(-329.03608 -146.74227)" fill="#ccc"/><path d="M479.03608,715.24227h-112a6,6,0,0,1,0-12h112a6,6,0,1,1,0,12Z" transform="translate(-329.03608 -146.74227)" fill="#ccc"/><polygon points="107.375 384.038 124.578 370.977 132.963 379.362 104.938 398.541 107.375 384.038" fill="#2f2e41"/><path d="M420.36583,566.74387H361.51722l2.064-6.68758h0c12.79222-4.63087,5.60682-14.58464,17.77517-20.66882,29.7631-14.88155,41.28561-59.28965,36.92732-76.84429l19.50438-.82469S464.72374,538.21174,420.36583,566.74387Z" transform="translate(-329.03608 -146.74227)" fill="#2f2e41"/><path d="M470.60568,535.3075a9.89147,9.89147,0,0,1-12.78172.23913l-.03826-.03142-.00131-.04919a9.47684,9.47684,0,0,0-.37995-2.4188,6.77026,6.77026,0,0,1-.24584,1.67423l-.04929.1836-.13219-.13647c-.11417-.11773-.22466-.23731-.32842-.35529a9.97468,9.97468,0,0,1-1.51926-2.30058,29.07888,29.07888,0,0,0-8.06828-10.05664,14.118,14.118,0,0,1-1.69263-1.62867,13.95425,13.95425,0,0,1,17.52315-21.25934l.08719.051-.04528.09025a7.26871,7.26871,0,0,1-1.29692,1.87076,9.47928,9.47928,0,0,0,1.9974-1.44308l.06337-.05975.0718.04951a14.01337,14.01337,0,0,1,2.55182,2.27146l.08134.09326a6.2294,6.2294,0,0,0,4.6128,2.12867,9.88837,9.88837,0,0,1,9.57517,11.58491l-.0112.06532-.06355.01925a8.48535,8.48535,0,0,1-3.45588.43121,9.64019,9.64019,0,0,0,3.07823.771l.13713.01088-.04353.13058a9.8818,9.8818,0,0,1-2.852,4.30008l-.03754.03285-.03986.03489a9.7103,9.7103,0,0,0-3.35461,6.74A9.964,9.964,0,0,1,470.60568,535.3075Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><path d="M472.40585,532.12862a9.86349,9.86349,0,0,1-.11121,1.06328,9.99679,9.99679,0,0,0,1.60714-4.95271c.01311-.27.04146-.539.07947-.80679A9.38181,9.38181,0,0,0,472.40585,532.12862Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M475.51806,520.10833a9.62507,9.62507,0,0,0,2.45985.6955,9.89773,9.89773,0,0,0,.90133-1.0997A8.38739,8.38739,0,0,1,475.51806,520.10833Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M479.14311,516.86068a9.949,9.949,0,0,1-.07038,2.5661,9.83448,9.83448,0,0,0,1.11307-2.29544l.04354-.13058-.13714-.01088A9.55592,9.55592,0,0,1,479.14311,516.86068Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M478.228,507.47444a9.91161,9.91161,0,0,0-7.25857-3.35623,6.22938,6.22938,0,0,1-4.61281-2.12868l-.08134-.09325a14.01337,14.01337,0,0,0-2.55182-2.27146l-.0718-.04951-.06336.05975a9.47874,9.47874,0,0,1-1.99742,1.44307,7.269,7.269,0,0,0,1.297-1.87076l.04525-.09024-.08718-.051a13.94385,13.94385,0,0,0-20.659,9.02719,13.94642,13.94642,0,0,1,19.163-5.13776l.08718.051-.04525.09024a7.26926,7.26926,0,0,1-1.297,1.87076,9.47868,9.47868,0,0,0,1.99741-1.44307l.06337-.05975.0718.04951a14.01337,14.01337,0,0,1,2.55182,2.27146l.08133.09326a6.22944,6.22944,0,0,0,4.61282,2.12867,9.89007,9.89007,0,0,1,9.565,8.12834,11.98677,11.98677,0,0,0,1.43129-.34829l.06355-.01925.01125-.06532A9.85036,9.85036,0,0,0,478.228,507.47444Z" transform="translate(-329.03608 -146.74227)" opacity="0.15"/><path d="M499.04886,466.75383a31.84958,31.84958,0,0,1-26.603,31.41149l-.15732.02566-.12171-.10142a30.51655,30.51655,0,0,0-6.656-4.22513,21.8005,21.8005,0,0,1,3.52508,4.15475l.339.50961-.611.0294c-.52742.02566-1.05152.0385-1.55741.0385a32.118,32.118,0,0,1-8.793-1.21919,93.63086,93.63086,0,0,0-41.47214-1.87907,45.458,45.458,0,0,1-7.53721.62884,44.93133,44.93133,0,0,1-14.1355-87.57594l.30883-.10225.12192.30138a23.40468,23.40468,0,0,1,1.765,7.11391,30.52291,30.52291,0,0,0,.75863-7.898l-.00973-.28026.2724-.06831a45.12252,45.12252,0,0,1,10.91843-1.33924l.39846.00165a20.05806,20.05806,0,0,0,14.956-6.62582,31.83962,31.83962,0,0,1,48.3716,1.48579l.13413.166-.08859.19457a27.32206,27.32206,0,0,1-6.30664,9.27243,31.04045,31.04045,0,0,0,8.4101-5.80282l.31794-.30842.22313.38293a31.8183,31.8183,0,0,1,4.33152,16.03983l-.00041.16063c-.00042.05672-.00042.11385-.00042.17056a31.26636,31.26636,0,0,0,9.1619,22.44376A32.08311,32.08311,0,0,1,499.04886,466.75383Z" transform="translate(-329.03608 -146.74227)" fill="#3f3d56"/><g opacity="0.15"><path d="M460.11959,391.50282a22.49407,22.49407,0,0,1-4.012,4.92175,30.96211,30.96211,0,0,0,6.26856-3.91791Q461.26814,391.96086,460.11959,391.50282Z" transform="translate(-329.03608 -146.74227)"/><path d="M478.55133,429.51105A31.97,31.97,0,0,1,483.13,435.089a32.54708,32.54708,0,0,1-2.97907-13.6731c0-.05672,0-.11385.0004-.17055l.00041-.16063a31.81856,31.81856,0,0,0-4.3315-16.03983l-.22314-.38294-.318.30841a31.112,31.112,0,0,1-5.80764,4.42232A31.01389,31.01389,0,0,0,478.55133,429.51105Z" transform="translate(-329.03608 -146.74227)"/><path d="M469.39025,406.7361l-.0004.16063c-.00041.05671-.00041.11384-.00041.17056,0,.31256.00566.62434.01439.93563a33.16272,33.16272,0,0,0,3.77185-6.50215l.08857-.19458-.13411-.166a32.10042,32.10042,0,0,0-5.76052-5.57135A31.89066,31.89066,0,0,1,469.39025,406.7361Z" transform="translate(-329.03608 -146.74227)"/><path d="M489.31279,443.85966a28.78932,28.78932,0,0,1-4.05843-4.93763,31.8105,31.8105,0,0,1-23.57,44.89467l-.15732.02568-.1217-.10143a30.5172,30.5172,0,0,0-6.65606-4.22512,21.79991,21.79991,0,0,1,3.52506,4.15473l.33907.50963-.611.02938c-.52745.02568-1.05154.03851-1.55741.03851a32.11821,32.11821,0,0,1-8.793-1.21919,93.631,93.631,0,0,0-41.47214-1.87907,45.45764,45.45764,0,0,1-7.53719.62883,44.7262,44.7262,0,0,1-29.84116-11.37979,44.97143,44.97143,0,0,0,40.60261,25.72841,45.45767,45.45767,0,0,0,7.5372-.62884,93.631,93.631,0,0,1,41.47214,1.87907,32.11819,32.11819,0,0,0,8.793,1.21919c.50588,0,1.03-.01283,1.55742-.03851l.611-.02938-.33907-.50962a21.79968,21.79968,0,0,0-3.52506-4.15474,30.5169,30.5169,0,0,1,6.656,4.22512l.12171.10143.15731-.02568a31.82584,31.82584,0,0,0,16.867-54.30565Z" transform="translate(-329.03608 -146.74227)"/></g></svg>
<figcaption markdown>
Un Polaroïd selon [unDraw]{target="_blank"}
</figcaption>
</figure>
En conclusion, quelque soit l'extension du fichier inclu, MkDocs-Material avec l'extension Snippets va parser (analyser, chercher à interpréter) le code contenu comme s'il s'agissait d'un fichier .md
.
S'il rencontre des caractères de balisage assimilable à MarkDown, HTML ou \(\LaTeX\), il va les convertir pour générer le code HTML final destiné au navigateur.
Lors de la construction du site, MkDocs convertit chacun des fichiers truc.md
qui se trouve dans le dossier docs
en créant un dossier nommé truc
contenant une copie du fichier truc.md
et un fichier index.html
généré à partir du code MarkDown de truc.md
pour permettre son bon affichage dans un navigateur.
De même avec l'extension mkdocs-jupyter pour les fichiers en .py
et .ipynb
.
En conséquence, il est préférable de placer tous les fichiers d'extraits à inclure à l'extérieur du dossier docs
par exemple dans un dossier nommé includes
.
Note
Une autre solution consiste à modifier l'extension du fichier truc.md
à inclure en truc.txt
, par exemple, et ainsi le conserver dans le dossier docs
sans qu'il soit automatiquement converti.
Tableau#
Exemple version basique : ...
Aligné à gauche | Aligné à droite | Texte centré | Défaut
:---|---:|:---:|---
abcdef | 1234 | xyz | etc
ghi jkl mno pqr | 567890 | ........ | etc
Aligné à gauche | Aligné à droite | Texte centré | Défaut |
---|---|---|---|
abcdef | 1234 | xyz | etc |
ghi jkl mno pqr | 567890 | ........ | etc |
La syntaxe de ce type de tableau est très naturelle et légère.
Le type d’alignement dans chaque colonne (à gauche, à droite, centré) est défini dans la seconde ligne par la position du caractère double point :
relativement aux tirets -
.
Afin d'améliorer la lecture d'un tableau en mode éditon de code,
on peut débuter et terminer chaque ligne par une barre verticale |
,
mais ce n’est pas obligatoire,
et aussi ajouter des tirets et des espaces supplémentaires.
Le nombre de tirets dans la seconde ligne n’est pas significatif.
Exemple version plus esthétique : ...
| Aligné à gauche | Aligné à droite | Texte centré | Défaut |
|:----------------|----------------:|:------------:|--------|
| abcdef | 1234 | xyz | etc |
| ghi jkl mno pqr | 567890 | ........ | etc |
Aligné à gauche | Aligné à droite | Texte centré | Défaut |
---|---|---|---|
abcdef | 1234 | xyz | etc |
ghi jkl mno pqr | 567890 | ........ | etc |
Astuces pour obtenir au clavier le caractère spécial |
: ...
- La barre verticale, également nommée tube ou pipe de l'Anglais, s'obtient avec la combinaison de touches AltGr+6 ;
Solution pour centrer un tableau et lui ajouter une légende : ...
<figure markdown>
Aligné à gauche | Aligné à droite | Texte centré | Défaut
:---|---:|:---:|---
abcdef | 1234 | xyz | etc
ghi jkl mno pqr | 567890 | ........ | etc
<figcaption markdown>
_Légende du **tableau**_
</figcaption>
</figure>
Aligné à gauche | Aligné à droite | Texte centré | Défaut |
---|---|---|---|
abcdef | 1234 | xyz | etc |
ghi jkl mno pqr | 567890 | ........ | etc |
Générer le code MarkDown d'un tableau : ...
On peut avantageusement utiliser :
-
Ou un script Python personnel... ;
Exemple :
from IPython.display import Markdown
chaine = "| d | b | h |" + "\n"
chaine += "|:-:" * 3 + "|" + "\n"
for i in range(16) :
chaine += f"| {i} | {bin(i)} | {hex(i)} |" + "\n"
Markdown(chaine)
A tester : ...
Note de bas de page#
Sur son site, Franck CHAMBON présente très complètement les notes de bas de page ;
Il y a également la référence officielle footnotes ;
Exemple : ...
Note pour le marquage de révision[^critic]
[^critic]:
Le [marquage de révision](https://github.com/CriticMarkup/CriticMarkup-toolkit){target=_blank}
s'applique aussi bien au rendu HTML qu'aux blocs de code et de texte brut.
Ceci est [une note de bas de page](#note-de-bas-de-page).
Note pour le marquage de révision1
Info
Il faut activer dans le fichier mkdocs.yml
l'extension
footnotes
pour autoriser les notes de bas de page.
markdown_extensions:
- footnotes
Ancre#
Pour qu'un lien hypertexte pointe vers un endroit précis de la page courante, ou d'une autre page afin de positionner correctement le navigateur, il est nécessaire de définir une ancre :
Ancre sur les titres : ...
A partir des titres, MkDocs crée automatiquement des ancres vers lesquelles pointent les liens de la table des matières.
Pour le nommage de ces ancres, par défaut, les masjuscules sont transformées en minuscules, les espaces sont remplacés par des -
et les caractères accentués deviennent des caractères de la table ASCII.
[Lien vers le titre "Caratères spéciaux"](#caracteres-speciaux)
Ancre sur les notes de bas page : ...
Une note de bas de page qui aurait bar
pour référence d'identification, génère deux ancres :
- l'une pour aller au contenu de la note de bas de page,
#fn:bar
; - et l'autre pour revenir dans le texte à une référence liée à cette note,
#reffn:bar
.
[Lien vers la note de bas de page "critic"](#fn:critic)
[Lien de retour vers une référence à la note de bas de page "critic"](#fnref:critic)
[Lien de retour vers une autre référence à la note de bas de page "critic"](#fnref2:critic)
Ancre à un endroit quelconque : ...
Pour créer une ancre à un endroit quelconque au beau milieu du MarkDown on peut y placer une balise HTML invisible en lui attribuant un identifiant : <a id="foo"></a>
.
Et puis, pour pointer vers cet endroit, on lui associe un lien débutant par le caractère dièse #
, suivi du nom de cet identifiant : [lien vers l'ancre identifiée "foo"](#foo)
[Lien vers l'ancre "toto"](#toto)
Bouton#
Sur son site, Franck CHAMBON présente très complètement l'ajout de boutons ;
Il y a également la référence officielle buttons ;
Exemple : ...
[![envelope]{align=left width=40%} <br>Poser une question à l'auteur...
:fontawesome-solid-paper-plane: ](mailto:eric.madec@ecmorlaix.fr
?subject=Le MarkDown de Mkdocs-Material&body=Votre question : ...
){ .md-button }
[![envelope]{align=left width=40%} <br>Poser une question à l'auteur...
:fontawesome-solid-paper-plane: ](mailto:eric.madec@ecmorlaix.fr
?subject=Le MarkDown de Mkdocs-Material&body=Votre question : ...
){ .md-button .md-button--primary }
Toujours en construction...#
Caractères spéciaux#
Entités HTML#
Puisque MarkDown interprète quatre espaces laissés au début d'une ligne de texte
comme une intention de généré l'affichage d'un bloc de code
et supprime automatiquement les espaces supplémentaires laissés vide,
une solution pour en introduire malgré tout est d'utiliser
l'entité HTML
correspondante à une espace insécable ( 
).
Une indentation de plus de quatre espaces,
et un vide laissé au milieu de cette ligne de texte.
<!-- un vrai commentaire qui ne s'affichera pas-->
   <!‐‐ ceci est…
      …un faux commentaire ‐‐>
Une indentation de plus de quatre espaces, et un vide laissé au milieu de cette ligne de texte.
<!‐‐ ceci est… …un faux commentaire ‐‐>
De la même façon tout autre symbole ou entité HTML peut être introduit ainsi dans du code MarkDown.
Icônes - Emojis#
Il y a la référence officielle icons-emojis ;
Sur son site, Franck CHAMBON présente l'ajout d'émojis et de caractères unicodes ;
Touches#
Sur son site, Franck CHAMBON présente des exemples d'ajout de touches ;
Il y a également la documentation et la référence officielles
Echappement#
En dehors des structures de type code inline ou bloc de texte brut,
il peut être nécessaire de mettre un caractère backslash \
devant
des caractères qui sinon sont interprétés en Markdown, HTML ou Latex.
Par exemple : ...
Code :
\##### Usage de l'antislash \\ :
1\. \`code`
5\. <@\>
3\. !\[image](url "info"){ heigt=30 align=left}
\> \~\~barré~~,
\^\^souligné^^,
\==surligné==, ...
\- \__MarkDown__ ;
\+ <em\>HTML<em\> ;
\* \$\LaTeX$ ;
Rendu :
##### Usage de l'antislash \ :
1. `code`
5. <@>
3. ![image](url "info"){ heigt=30 align=left}
> ~~barré~~, ^^souligné^^, ==surligné==, ...
- __MarkDown__ ;
+ <em>HTML<em> ;
* $\LaTeX$ ;
Code :
##### Usage de l'antislash \ :
1. `code`
5. <@>
3. ![image](url "info"){ heigt=30 align=left}
> ~~barré~~,
^^souligné^^,
==surligné==, ...
- __MarkDown__
+ <em>HTML<em>
* $\LaTeX$
Rendu :
Usage de l'antislash :#
code
- <@>
barré, souligné, surligné, ...
- MarkDown
- HTML
- \(\LaTeX\)
Ressources#
https://www.jdbonjour.ch/cours/markdown-pandoc/
http://pageperso.lif.univ-mrs.fr/~edouard.thiel/mkdocs-et/
https://agea.github.io/tutorial.md/
https://learninglab.gitlabpages.inria.fr/mooc-impacts-num/mooc-impacts-num-ressources/Exemples.html
https://www.markdownguide.org/
https://www.markdowntutorial.com/
https://www.ionos.fr/digitalguide/sites-internet/developpement-web/markdown/
https://docs.microsoft.com/en-us/contribute/markdown-reference
https://jupyterbook.org/content/myst.html Markedly Structured Text
-
Le marquage de révision s'applique aussi bien au rendu HTML qu'aux blocs de code et de texte brut.
Ceci est une note de bas de page. ↩↩