====== Comment fixer la largeur d'un tableau? ====== Fondamentalement, deux techniques sont à notre disposition pour jouer sur la largeur d'un tableau pendant sa mise en forme, pour obtenir à la fin la largeur totale désirée. On peut: * étirer les espaces entre les colonnes ; * étirer certaines des colonnes du tableau. Voici comment appliquer ces deux possibilités. ===== En jouant sur les espaces intercolonnes ===== ==== Avec les fonctions de base de LaTeX ==== Les fonctionnalités de base de \LaTeX permettent uniquement d'étirer les espaces: l'environnement ''tabular*'' prend un argument supplémentaire qui indique la largeur totale désirée pour le tableau, sous la forme d'une longueur comme ''15cm'' ou ''\columnwidth''. Cet argument s'écrit avant celui qui décrit la mise en forme des colonnes du tableau (avec ''clpr''). Pour que cela fonctionne, il faut également utiliser la commande ''\extracolsep'' dans l'argument suivant (celui qui décrit la mise en forme des colonnes), à l'intérieur d'une directive ''@{}''. Voici comment ça se présente: \begin{tabular*}{\columnwidth}{@{\extracolsep{\fill}}lllr} La commande ''\extracolsep'' s'applique également à tous les espaces intercolonnes situés à sa droite ; si vous ne souhaitez pas que tous les espaces soient étirés, ajoutez ''\extracolsep{0pt}'' pour annuler l'effet de la commande initiale. On peut également utiliser ''\extracolsep{\stretch{1}}''. ''\extracolsep'' ne doit pas être confondu avec ''\tabcolsep'', qui est l'espacement de part et d'autre d'une colonne et non celui qui sépare celles-ci. \begin{tabular*}{0.5\linewidth}{ @{\extracolsep{\stretch{1}}} l p{8cm} @{} } \hline Fonction & Rôle \\ \hline atoi() & transforme une chaîne de caractères en entier \\ fscanf() & remplit les variables dont on donne l'adresse à partir d'un fichier (attention, d'utilisation délicate) \\ printf() & impression formatée d'une chaîne de caractères \\ sqrt() & racine carrée (penser à lier à la bibliothèque mathématique) \\ \hline \end{tabular*} \begin{tabular*}{0.5\linewidth}{ @{\extracolsep{\stretch{1}}} l p{8cm} @{} } \hline Fonction & Rôle \\ \hline atoi() & transforme une chaîne de caractères en entier \\ fscanf() & remplit les variables dont on donne l'adresse à partir d'un fichier (attention, d'utilisation délicate) \\ printf() & impression formatée d'une chaîne de caractères \\ sqrt() & racine carrée (penser à lier à la bibliothèque mathématique) \\ \hline \end{tabular*} ==== Avec l'extension “array” ==== Une autre possibilité, avec l'extension [[ctanpkg>array]]: \usepackage{array} ... \begin{tabular*}{0.5\linewidth}{ !{\extracolsep{\stretch{1}}} l p{8cm} } \hline Fonction & Rôle \\ \hline atoi() & transforme une chaîne de caractères en entier \\ fscanf() & remplit les variables dont on donne l'adresse à partir d'un fichier (attention, d'utilisation délicate) \\ printf() & impression formatée d'une chaîne de caractères \\ sqrt() & racine carrée (penser à lier à la bibliothèque mathématique) \\ \hline \end{tabular*} \documentclass{article} \usepackage[french]{babel} \usepackage{lmodern} \usepackage{array} \pagestyle{empty} \begin{document} \begin{tabular*}{0.5\linewidth}{ !{\extracolsep{\stretch{1}}} l p{8cm} } \hline Fonction & Rôle \\ \hline atoi() & transforme une chaîne de caractères en entier \\ fscanf() & remplit les variables dont on donne l'adresse à partir d'un fichier (attention, d'utilisation délicate) \\ printf() & impression formatée d'une chaîne de caractères \\ sqrt() & racine carrée (penser à lier à la bibliothèque mathématique) \\ \hline \end{tabular*} \end{document} ''!{code}'' est équivalent à ''@{code}'' à la différence près que la séparation ''\tabcolsep'' n'est pas supprimée. Donc soit on supprime cette séparation des deux côtés du tableau, soit on utilise cette fonction ''!{code}''. ===== En jouant sur la largeur des colonnes ===== Dans les cas simples, il est bien sûr possible de le faire « à la main », en fixant la largeur des colonnes: \begin{tabular}{p{2cm}p{3cm}} ... \end{tabular} ou même en faisant dépendre la largeur des colonnes de la largeur de la page: \begin{tabular}{p{.25\textwidth}p{.33\textwidth}} ... \end{tabular} Mais diverses extensions ont été développées pour s'en occuper pour vous. ==== Avec l'extension “tabularx” ==== L'extension [[ctanpkg>tabularx]] définit un nouveau type de colonne: ''X''. Une colonne de format ''X'' se comporte comme une colonne ''p{⟨//largeur//⟩}'', mais elle est capable de s'étendre pour remplir l'espace disponible. Il n'est pas nécessaire de passer un argument ''⟨//largeur//⟩'' S'il y a plus d'une colonne ''X'' dans un tableau, l'espace libre est réparti entre elles. Voici un exemple qui donne un tableau s'étalant sur toute la largeur d'une ligne, et divisé en deux colonnes de largeur égale: \usepackage{tabularx} ... \begin{tabularx}{\linewidth}{|X|X|} \hline salut & coucou \\ bonjour & hello \\ \hline \end{tabularx} \documentclass{article} \usepackage{lmodern} \usepackage[width=8cm]{geometry} \usepackage{tabularx} \usepackage[french]{babel} \pagestyle{empty} \begin{document} \begin{tabularx}{\linewidth}{|X|X|} \hline salut & coucou \\ bonjour & hello \\ \hline \end{tabularx} \end{document} ==== Avec l'extension “tabulary” ==== L'extension [[ctanpkg>tabulary]] (du même auteur que [[ctanpkg>tabularx]]) fournit un moyen d'« équilibrer » l'espace occupé par les colonnes d'un tableau. Elle définit des spécifications de colonne ''C'', ''L'', ''R'' et ''J'', qui donnent, respectivement, des versions centrée, gauche, droite et justifiée des colonnes qui se partagent l'espace en trop. L'extension examine la largeur « naturelle » de chaque colonne (c'est-à-dire la largeur qu'elle aurait sur une feuille de papier de largeur infinie) et alloue de l'espace à chaque colonne en conséquence. Elle fait quelques vérifications pour que les entrées vraiment grandes n'écrasent pas tout le reste (il y a une notion de « largeur maximale »), et pour que les entrées minuscules ne deviennent pas plus petites qu'un minimum spécifié. Bien sûr, tout ce travail signifie que l'extension doit compiler chaque ligne plusieurs fois, donc tout ce qui produit des effets de bord (par exemple, un compteur qui serait utilisé pour compter les lignes) devient inévitablement peu fiable, et ne devrait même pas être essayé. ==== Avec d'autres extensions ==== L'extension [[ctanpkg>ltxtable]] combine les fonctionnalités des extensions [[ctanpkg>longtable]] et [[ctanpkg>tabularx]]. Lisez bien [[texdoc>ltxtable|sa documentation]], car son utilisation est peu intuitive. L'extension [[ctanpkg>easytable]] fonctionne un peu comme [[ctanpkg>tabularx]]. ----- //Sources :// * [[faquk>FAQ-fixwidtab|Fixed-width tables]], * [[https://texblog.org/2019/06/03/control-the-width-of-table-columns-tabular-in-latex/|Control the width of table columns (tabular) in LaTeX]], * [[https://tex.stackexchange.com/questions/223445/tabular-fixed-width|Tabular fixed width]]. {{htmlmetatags>metatag-keywords=(LaTeX,tables,mise en forme des tableaux,largeur fixe,tableau de la largeur de la page,flottants) metatag-og:title=(Comment fixer la largeur d'un tableau) metatag-og:site_name=(FAQ LaTeX francophone) }}