Format Markdown
- tutoriel
- markdown
- François Brucker
Une introduction au format markdown.
Markdown est un format de fichier texte, donc modifiable par tout éditeur de texte. L'extension de fichier est ".md".
L'intérêt de ce format de fichier texte est qu'il est parfaitement lisible dans tout éditeur de texte et qu'on peut de plus le compiler dans un autre format comme le pdf ou encore le html si on veut le partager.
Pour écrire confortablement du markdown. Installez un plugin pour votre éditeur préféré. Si vous avez suivi les prés-requis, vous avez déjà du installer l'extension pour vscode.
Syntaxe
Le markdown est un format très simple. Il permet de structurer minimalement un texte, ce qui est suffisant pour la plupart des rapports/documentations de code.
Le texte ci-après est un exemple de ce que l'on peut écrire en markdown.
# Un petit peu de Markdown
## quoi ?
Le [Markdown](https://fr.wikipedia.org/wiki/Markdown) est un format texte éditable et visualisable dans tout éditeur.
## comment ?
### style
- peut écrire en *italique*
- ou en **gras**
- du `code`
- des équations latex comme $2 \pi + \frac{1}{2}$
### bloc
On peut aussi écrire des blocs de code, comme :
1. des équations en latex
2. du code python
3. du texte brut
Balise à connaître
Les principales fonctionnalités sont décrites dans cette liste.
Sections
# titre du document
## section
### sous-section
#### sous-sous-section
Paragraphes
Un saut de ligne est nécessaire pour commencer un nouveau paragraphe. Aller à la ligne sera équivalent à un espace.
Style inline
Dans le flot du texte, on peut mettre en exergue des parties de texte :
- en italique :
*texte*
- en gras :
**texte**
- en gras et en italique :
***texte***
barré:~~texte~~
code
:`texte`
- équations :
$\LaTeX$
Style bloc
En markdown, un bloc commence et finit par une ligne vide.
Plusieurs symboles peuvent être utilisées :
Listes
Comme chaque bloc, les listes commencent et finissent toujours par une ligne vide. Il y a deux types de listes :
-
non ordonnées. Chaque item peut commencer par un
*
, un-
ou encore un+
. Choisissez en un et tenez vous y dans tout le document :- premier élément - deuxième élément
-
- on met le bon numéro
- on met le bon numéro
Liens
Il y a plusieurs possibilités :
- via un nom :
[nom](lien)
. Par exemple[LMGTFY](https://www.google.fr)
qui se compile en : LMGTFY - lien direct :
<https://www.google.fr>
qui se compile en : https://www.google.fr.
On utilise les liens pour les images, il suffit de rajouter un !
avant. Par exemple ![ada lovelace](https://upload.wikimedia.org/wikipedia/commons/0/0f/Ada_lovelace.jpg)
qui se compile en :
Tableaux
| nom colonne 1 | nom colonne 2 | nom colonne 3 |
|---------------|---------------|---------------|
| m (1, 1) | m (1, 2) | m (1, 3) |
| m (2, 1) | m (2, 2) | m (2, 3) |
Qui se compile en :
nom colonne 1 | nom colonne 2 | nom colonne 3 |
---|---|---|
m (1, 1) | m (1, 2) | m (1, 3) |
m (2, 1) | m (2, 2) | m (2, 3) |
En markdown un tableau a forcément des noms de colonnes. Les deux premières lignes sont donc indispensables.
Il existe des extensions de markdown, comme commonMark utilisé pour ce site. qui permettent de faire beaucoup plus de choses avec des tableaux.
Code
Il y a deux façon d'écrire du code en markdown :
- en mettant le caractère "`" avant et après le code :
print("du code")
. Le code écrit de cette façon s'insère dans la phrase - en mode bloc en commençant et en finissant le bloc par une ligne "```".
Exemple de code en mode bloc :
``` for l in "MPCI": print("Donnez moi un :", l, "!") ```
Il se compilera en :
for l in "MPCI":
print("Donnez moi un :", l, "!")
On a l'habitude de préciser le langage de programmation utilisé. On écrit donc :
```python for l in "MPCI": print("Donnez moi un :", l, "!") ```
Qui, selon le compilateur markdown utilisé, pourra être affiché/compilé avec la coloration syntaxique :
for l in "MPCI":
print("Donnez moi un :", l, "!")
Préférez toujours cette dernière façon d'écrire du code. C'est plus clair à la lecture et plus joli à la compilation
Formules mathématiques
Lorsque l'on écrit des textes scientifiques, vient inévitablement la question de l'écriture des équations.
Formules en Latex
Le langage Latex permet d'écrire toutes les équations imaginable (et même plus) avec un petit langage que l'on peut utiliser directement dans un éditeur de texte (ceux qui ont déjà utilisé l'éditeur d'équation de Word savent que c'est l'enfer de devoir tout cliquer).
L'ancêtre de Latex : Tex, a été créé par le célèbre informaticien Donald Knuth par ce qu'il n'existait rien sur ordinateur à l'époque pour écrire ses livres en respectant une typographie correcte.
Une fois ce langage appris, il est étonnement clair, même non compilé en jolies formules. Avec un peut d'habitude, on voit bien que : $$\cos x=\sum_{k=0}^{\infty}\frac{(-1)^k}{(2k)!}x^{2k}$$
est égal à :
Quelques aides :
Formules en markdown
On peut écrire en markdown les équations latex.
- pour une équation dans le texte, on dit inline on entoure notre équation par des
$
- pour équation au milieu de la page, on dit display, on entoure notre équation par des
$$
et on saute une ligne avant et après les$$
. comme dans l'exemple ci-après.
Equation en mode inline :
je pense que $3 + 2$ vaut 5.
Equation en mode display :
$$
3+2
$$
Lorsque vous faites de l'exportation en html, les mathématiques sont représentées en utilisant la bibliothèque Mathjax.
Plugin Markdown vscode
Il existe aussi deux plugins intéressants pour écrire ou compiler du markdown avec vscode :
- Markdown All in One qui possède tout le nécessaire pour manipuler de façon agréable le markdown (n'hésitez pas à regarder la documentation, elle est très bien faite).
- Markdownlint qui est un analyseur syntaxique pour Markdown (il va souligner en jaune ce qui n'est pas du bon markdown)
Pour aller plus loin
Guides
- base markdown et latex : https://ashki23.github.io/markdown-latex.html
- base markdown : https://www.markdownguide.org/ par exemple
- Mathjax et latex
Variantes de markdown
Le format markdown est basique. Il possède plein de variantes qui permettent d'étendre ses possibilités. Deux d'entre elles sont devenus des standard de fait :
- commonMark utilisé pour ce site.
- github flavored markdown.
- kramdown.