Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente |
composition:tableaux:notes_de_bas_de_tableau [2018/12/09 10:25] – jejust | 3_composition:tableaux:notes_de_bas_de_tableau [2022/01/01 20:07] (Version actuelle) – Changement de titre. jejust |
---|
====== Comment créer des notes de bas de page dans un tableau? ====== | ====== Comment mettre une note de bas de page dans un tableau? ====== |
| |
| Pour des raisons trop longues à expliquer ici, il n'est pas possible d'utiliser directement la commande ''\footnote'' à l'intérieur d'un tableau: |
| un appel à ''\footnote'' ne conserve que l'appel de note tandis que la note elle-même est perdue par l'environnement ''tabular'' ou ses équivalents. |
| |
$\Reponse$ Pour des raisons trop longues à expliquer ici, il n'est pas | Ceci correspond à la recommandation typographique classique: notes de bas de page et tables ne devraient pas être mélangées. |
possible d'utiliser directement la commande ''\footnote'' à l'intérieur | Cependant, plusieurs solutions permettent de contourner cette recommandation. Elles sont regroupés en deux familles |
d'un tableau: un appel à ''\footnote'' ne conserve que l'appel de | : celles travaillant avec des « notes de bas de table », particulièrement recommandées, et les autres d'utilisation plus ponctuelle |
note, la note elle-même est perdue. | (mais bien entendu fonctionnelles). |
Une solution simple pour contourner le problème est d'inclure le tableau dans | |
une ''minipage''. Dans ce cas, la note n'est pas perdue, mais elle sera | |
placée dans la ''minipage'', donc juste au-dessous du tableau, et non en | |
bas de la page. L'inconvénient est que ''minipage'' oblige à passer une | |
largeur explicite qui peut ne pas être adaptée au tableau dont on ne | |
connaît pas toujours la largeur finale. Un recours possible pourra | |
être trouvé en l'environnement ''varwidth'' du package | |
[[ctanpkg>varwidth|varwidth]]. Reportez-vous à | |
l'exemple~\ref{expl=Utilisation_varwidth}. | |
| |
Utilisation de l'environnement ''varwidth'': | ===== Avec les méthodes utilisant des notes de bas de table ===== |
| |
<code latex> | ==== Les extensions “threeparttable” et “threeparttablex” ==== |
\documentclass{article} | |
| L'extension [[ctanpkg>threeparttable]] définit un environnement (du même nom) conçu pour faciliter la création de tables |
| avec un titre et des notes de bas de table. Les références sont produites à l'aide de la commande ''tnote''. |
| Quant aux descriptions, elles sont précisées à l'aide de l'environnement ''tablenotes''. |
| L'exemple suivant met tout cela en pratique. |
| |
| <code latex exempleThreeparttable.tex> |
| \documentclass[french]{article} |
| \usepackage[utf8]{inputenc} |
| \usepackage[T1]{fontenc} |
| \usepackage{babel} |
| |
| \usepackage{threeparttable} |
| |
| \begin{document} |
| |
| \begin{center} |
| \begin{threeparttable} |
| \caption{Les angles biaisés ($\beta$) pour $\fam0 Mu(H)+X_2$ et $\fam0 Mu(H)+HX$~\tnote{a}} |
| \begin{tabular}{rlcc}% ou tabularx, etc. |
| \hline |
| & & $\fam0 H(Mu)+F_2$ & $\fam0 H(Mu)+Cl_2$ \\ |
| \hline |
| & $\beta$(H) & $80,9^\circ\tnote{b}$ & $83,2^\circ$ \\ |
| & $\beta$(Mu) & $86,7^\circ$ & $87,7^\circ$ \\ |
| \hline |
| \end{tabular} |
| \begin{tablenotes} |
| \item[a] pour la réaction d'abstraction, $\fam0 Mu+HX \rightarrow MuH+X$. |
| \item[b] 1 degré${} = \pi/180$ radians. |
| \end{tablenotes} |
| \end{threeparttable} |
| \end{center} |
| |
| \end{document} |
| </code> |
| |
| Cette extension fonctionne bien avec le texte ordinaire et à l'intérieur de flottants. L'extension [[ctanpkg>threeparttablex]] prend en plus en charge les tables ''longtable''. |
| |
| ==== L'extension “ctable” ==== |
| |
| L'extension [[ctanpkg>ctable]] développe le modèle de [[ctanpkg>threeparttable]] et utilise aussi les idées de [[ctanpkg>booktabs]]. La commande ''\ctable'' effectue la totalité du travail: mettre en forme la table, placer la légende et définir les notes. La « table » peut être composée de diagrammes et un paramètre optionnel de ''\ctable'' permet d'avoir là un flottant traité comme une figure, plutôt que comme une table. |
| |
| ===== Avec d'autres méthodes ===== |
| |
| ==== Avec l'environnement “minipage” ==== |
| |
| Une solution simple pour contourner le problème est d'inclure le tableau dans une ''minipage''. Cette méthode présente trois inconvénients : |
| * la note n'est pas perdue, mais elle sera placée dans la ''minipage'', donc juste au-dessous du tableau, et non pas en bas de la page ; |
| * la composition de la note, devenue une note de bas de table, n'a pas la présentation attendue ; |
| * ''minipage'' oblige à passer une largeur explicite qui peut ne pas être adaptée au tableau dont on ne connaît pas toujours la largeur finale. Un recours possible pourra être trouvé en l'environnement ''varwidth'' de l'extension [[ctanpkg>varwidth]], dont voici un exemple. |
| |
| <code latex exempleVarwidth.tex> |
| \documentclass[french]{article} |
| \usepackage[utf8]{inputenc} |
| \usepackage[T1]{fontenc} |
| \usepackage{babel} |
| |
\usepackage{varwidth} | \usepackage{varwidth} |
</code> | </code> |
| |
| ==== En scindant la commande “\footnote” ==== |
| |
| La commande ''\footnote'' peut être décomposée en deux commandes : |
| * la commande ''\footnotemark'', qui place le numéro de la note en exposant ; |
| * et ''\footnotetext'', qui place le texte de la note en bas de la page. Cette dernière commande devra être exécutée en dehors du tableau. |
| |
$\Reponse$ Une première solution consiste à utiliser le package | Cette méthode simple, décrite dans le livre de Leslie Lamport, doit faire l'objet de beaucoup d'attention lorsque les notes de bas de page se multiplient et deviennent sources de confusion. Voici un exemple de cette méthode. |
[[ctanpkg>threeparttable|threeparttable]] qui définit un environnement du même nom. Il a été | |
conçu pour faciliter la création de tableaux avec un titre et des notes en | |
bas de tableau. Les références sont produites à l'aide de la commande | |
''tnote''. Quant aux descriptions, elles sont précisées à l'aide de | |
l'environnement ''tablenotes''. L'exemple~\vref{ex=3parttab} met tout cela | |
en pratique. | |
| |
| |
<note> | |
Pour l'instant, il n'y a pas de méthode commode et élégante pour numéroter automatiquement les notes. | |
</note> | |
| |
| |
Insertion de notes dans un tableau\label{ex=3parttab} | |
| |
<code latex> | |
\documentclass{article} | |
\usepackage{threeparttable} | |
\begin{document} | |
\begin{center} | |
\begin{threeparttable} | |
\caption{Les angles biaisés ($\beta$) pour | |
$\fam0 Mu(H)+X_2$ et $\fam0 Mu(H)+HX$~\tnote{a}} | |
\begin{tabular}{rlcc}% ou tabluarx, etc. | |
\hline | |
& & $\fam0 H(Mu)+F_2$ & $\fam0 H(Mu)+Cl_2$ \\ | |
\hline | |
&$\beta$(H) & $80.9^\circ\tnote{b}$ | |
& $83.2^\circ$ \\ | |
&$\beta$(Mu) & $86.7^\circ$ & $87.7^\circ$ \\ | |
\hline | |
\end{tabular} | |
\begin{tablenotes} | |
\item[a] pour la réaction d'abstraction, | |
$\fam0 Mu+HX \rightarrow MuH+X$. | |
\item[b] 1 degré${} = \pi/180$ radians. | |
\end{tablenotes} | |
\end{threeparttable} | |
\end{center} | |
\end{document} | |
</code> | |
| |
| |
| |
$\Reponse$ Pour pallier le problème de la commande ''\footnote'', on peut la | |
décomposer en deux : la commande ''\footnotemark'', qui place le numéro | |
de la note en exposant, et ''\footnotetext'', qui place le texte de la note | |
en bas de la page. Cette dernière commande devra être exécutée en | |
dehors du tableau. | |
| |
La méthode simple est décrite dans l'exemple suivant: | |
| |
<code latex> | <code latex> |
\begin{tabular}{ll} | \begin{tabular}{ll} |
</code> | </code> |
| |
% | <note> |
Notez en particulier le caractère \texcode{\%} suivant le | Notez en particulier le caractère ''%'' suivant le ''\end{tabular}''. Si vous ne le mettez pas, la note risque d'être insérée sur la mauvaise page. |
\eenv{tabular}. Si vous ne le mettez pas, la note risque d'être | </note> |
insérée sur la mauvaise page. | |
| |
Cette méthode présente cependant le problème suivant : | |
si l'on a plusieurs notes dans le | |
même tableau, les valeurs des compteurs ne seront pas les bonnes, puisque la | |
commande ''\footnotemark'' va incrémenter plusieurs fois le compteur avant | |
que ce même compteur soit utilisé par ''\footnotetext''. Une solution, | |
pour contourner ce problème, est de mémoriser la valeur du compteur avant | |
le tableau, et de remettre le compteur de notes à cette valeur avant | |
d'exécuter les ''\footnotetext''s (qui, elles, n'incrémentent pas le | |
compteur de notes) ; | |
Par exemple : | |
% | |
| |
| Cette méthode rencontre un problème si un tableau contient plusieurs notes. Les valeurs des compteurs ne seront pas les bonnes, puisque la commande ''\footnotemark'' va incrémenter plusieurs fois le compteur avant que ce même compteur soit utilisé par ''\footnotetext''. Une solution, pour contourner ce problème, est de mémoriser la valeur du compteur avant le tableau, et de remettre le compteur de notes à cette valeur avant d'exécuter les ''\footnotetext'' (qui, elles, n'incrémentent pas le compteur de notes). En voici un exemple. |
<code latex> | <code latex> |
\newcounter{footnoteaux} | \newcounter{footnoteaux} |
</code> | </code> |
| |
| ==== En redéfinissant les commandes \footmark et \foottext ==== |
| |
Une autre solution apportée sur [[https://groups.google.com/forum/#!forum/fr.comp.text.tex|fctt]] est | Une autre solution apportée sur [[https://groups.google.com/forum/#!forum/fr.comp.text.tex|fctt]] consiste à redéfinir les commandes ''\footmark'' et ''\foottext''. |
la définition de commandes ''\footmark'' et ''\foottext'' définies ainsi: | |
| |
<code latex> | <code latex> |
</code> | </code> |
| |
| Les commandes s'utilisent ensuite ainsi (attention aux ''%'') : |
Les commandes s'utilisent ainsi (attention aux ''%''): | |
| |
<code latex> | <code latex> |
</code> | </code> |
| |
| Cette méthode présente quelques restrictions : |
| * la méthode est inapplicable dans un flottant ''table'' ; |
| * chaque commande ''footmark'' doit être suivie d'une commande ''\foottext'' ; |
| * l'utilisation des arguments optionnels est déconseillée. |
| |
Les restrictions sont les suivantes: | ==== Les extensions “longtable”, “tabularx” et “supertabular” ==== |
| |
\begin{enumerate} | Les notes au sein des tableaux produits à l'aide des extensions [[ctanpkg>longtable]], [[ctanpkg>tabularx]] et [[ctanpkg>supertabular]] fonctionnent mais ces extensions peuvent être moins flexibles que l'environnement de base ''tabular'' pour d'autres fonctionnalités. |
\item la méthode est inapplicable dans un flottant ''table'', | |
\item un paquet de ''footmark'' doit être suivi du même nombre de ''\foottext'', | |
\item l'utilisation des arguments optionnels est déconseillée. | |
\end{enumerate} | |
| |
| ==== L'extension “mdwtab” ==== |
| |
$\Reponse$ Les notes au sein des tableaux produits à l'aide des packages | L'extension [[ctanpkg>mdwtab]] implémente les mêmes fonctionnalités que l'extension [[ctanpkg>array]] et, en prime, fait fonctionner les notes de bas de page et propose d'autres fonctionnalités pour améliorer les tableaux. Toutefois, n'envisagez cette solution que si votre document n'est pas trop complexe. En effet, [[ctanpkg>mdwtab]] est incompatible avec bon nombre d'extensions. |
[[ctanpkg>longtable|longtable]] et [[ctanpkg>supertabular|supertabular]] fonctionnent, elles. | |
| |
| ==== L'extension “tablefootnote” ==== |
| |
$\Reponse$ Le package [[ctanpkg>mdwtab|mdwtab]] implémente les mêmes fonctionnalités | L'extension [[ctanpkg>tablefootnote]] fournit une commande ''\tablefootnote'' qui traite le sujet avec une belle sobriété. |
que [[ctanpkg>array|array]] mais, en outre, refait fonctionner les notes de bas | |
de page. Toutefois, n'envisagez cette solution que si votre document | |
n'est pas trop complexe. En effet, [[ctanpkg>mdwtab|mdwtab]] est incompatible | |
avec bon nombre de packages. | |
| |
| ==== L'extension “footnotehyper” ==== |
| |
{{htmlmetatags>metatag-keywords=(LaTeX) | L'extension [[ctanpkg>footnotehyper]] fournit un environnement ''savenotes'' qui collecte toutes les notes de bas de page qu'il contient et les émet lorsqu'il prend fin. Ainsi, si vous placez votre environnement ''tabular'' dans un environnement ''savenotes'', les notes de bas de page apparaîtront comme souhaité. Vous pouvez également utiliser la commande ''\makesavenoteenv{tabular}'' dans le préambule de votre document et les tableaux se comporteront tous comme s'ils se trouvaient dans un environnement ''savenotes''. |
metatag-og:title=(Comment créer des notes de bas de page dans un tableau?) | |
| ----- |
| //Source:// [[faquk>FAQ-footintab|Footnotes in tables]] |
| |
| {{htmlmetatags>metatag-keywords=(LaTeX,tableaux,note de bas de page,tableau) |
| metatag-og:title=(Comment mettre des notes de bas de page dans un tableau) |
metatag-og:site_name=(FAQ LaTeX francophone) | metatag-og:site_name=(FAQ LaTeX francophone) |
}} | }} |
| |