textwrap --- Text wrapping and filling

Source code: Lib/textwrap.py


Le module textwrap fournit quelques fonctions pratiques, comme TextWrapper, la classe qui fait tout le travail. Si vous ne faites que formater ou ajuster une ou deux chaînes de texte, les fonctions de commodité devraient être assez bonnes ; sinon, nous vous conseillons d'utiliser une instance de TextWrapper pour une meilleure efficacité.

textwrap.wrap(text, width=70, *, initial_indent='', subsequent_indent='', expand_tabs=True, replace_whitespace=True, fix_sentence_endings=False, break_long_words=True, drop_whitespace=True, break_on_hyphens=True, tabsize=8, max_lines=None, placeholder=' [...]')

Reformate le paragraphe simple dans text (une chaîne de caractères) de sorte que chaque ligne ait au maximum largeur caractères. Renvoie une liste de lignes de sortie, sans ligne vide ou caractère de fin de ligne à la fin.

Optional keyword arguments correspond to the instance attributes of TextWrapper, documented below.

Consultez la méthode TextWrapper.wrap() pour plus de détails sur le comportement de wrap().

textwrap.fill(text, width=70, *, initial_indent='', subsequent_indent='', expand_tabs=True, replace_whitespace=True, fix_sentence_endings=False, break_long_words=True, drop_whitespace=True, break_on_hyphens=True, tabsize=8, max_lines=None, placeholder=' [...]')

Formate le paragraphe unique dans text et renvoie une seule chaîne dont le contenu est le paragraphe formaté. fill() est un raccourci pour

"\n".join(wrap(text, ...))

En particulier, fill() accepte exactement les mêmes arguments nommés que wrap().

textwrap.shorten(text, width, *, fix_sentence_endings=False, break_long_words=True, break_on_hyphens=True, placeholder=' [...]')

Réduit et tronque le text donné pour l'adapter à la largeur donnée.

First the whitespace in text is collapsed (all whitespace is replaced by single spaces). If the result fits in the width, it is returned. Otherwise, enough words are dropped from the end so that the remaining words plus the placeholder fit within width:

>>> textwrap.shorten("Hello  world!", width=12)
'Hello world!'
>>> textwrap.shorten("Hello  world!", width=11)
'Hello [...]'
>>> textwrap.shorten("Hello world", width=10, placeholder="...")
'Hello...'

Les arguments nommés optionnels correspondent aux attributs d'instance de TextWrapper, documentés ci-dessous. Notez que l'espace blanc est réduit avant que le texte ne soit passé à la fonction fill() de TextWrapper, donc changer la valeur de tabsize, expand_tabs, drop_whitespace, et replace_whitespace est sans effet.

Ajouté dans la version 3.4.

textwrap.dedent(text)

Supprime toutes les espaces en de tête de chaque ligne dans text.

Ceci peut être utilisé pour aligner les chaînes à trois guillemets avec le bord gauche de l'affichage, tout en les présentant sous forme indentée dans le code source.

Notez que les tabulations et les espaces sont traitées comme des espaces, mais qu'elles ne sont pas égales : les lignes "  hello" et "\thello" sont considérées comme n'ayant pas d'espaces de tête communes.

Les lignes contenant uniquement des espaces sont ignorées en entrée et réduites à un seul caractère de saut de ligne en sortie.

Par exemple :

def test():
    # end first line with \ to avoid the empty line!
    s = '''\
    hello
      world
    '''
    print(repr(s))          # prints '    hello\n      world\n    '
    print(repr(dedent(s)))  # prints 'hello\n  world\n'
textwrap.indent(text, prefix, predicate=None)

Ajoute prefix au début des lignes sélectionnées dans text.

Les lignes sont séparées en appelant text.splitlines(True).

Par défaut, prefix est ajouté à toutes les lignes qui ne sont pas constituées uniquement d'espaces (y compris les fins de ligne).

Par exemple :

>>> s = 'hello\n\n \nworld'
>>> indent(s, '  ')
'  hello\n\n \n  world'

L'argument optionnel predicate peut être utilisé pour contrôler quelles lignes sont en retrait. Par exemple, il est facile d'ajouter prefix aux lignes vides et aux lignes blanches seulement :

>>> print(indent(s, '+ ', lambda line: True))
+ hello
+
+
+ world

Ajouté dans la version 3.3.

wrap(), fill() et shorten() travaillent en créant une instance TextWrapper et en appelant une méthode unique sur celle-ci. Cette instance n'est pas réutilisée, donc pour les applications qui traitent plusieurs chaînes de texte en utilisant wrap() et/ou fill(), il peut être plus efficace de créer votre propre objet TextWrapper.

Le formatage du texte s'effectue en priorité sur les espaces puis juste après les traits d'union dans des mots séparés par des traits d'union ; ce n'est qu'alors que les mots longs seront cassés si nécessaire, à moins que TextWrapper.break_long_words soit défini sur False.

class textwrap.TextWrapper(**kwargs)

Le constructeur TextWrapper accepte un certain nombre d'arguments nommés optionnels. Chaque argument nommé correspond à un attribut d'instance, donc par exemple

wrapper = TextWrapper(initial_indent="* ")

est identique à

wrapper = TextWrapper()
wrapper.initial_indent = "* "

You can reuse the same TextWrapper object many times, and you can change any of its options through direct assignment to instance attributes between uses.

Les attributs d'instance de la classe TextWrapper (et les arguments nommés au constructeur) sont les suivants :

width

(par défaut : 70) Longueur maximale des lignes reformatées. Tant qu'il n'y a pas de mots individuels dans le texte d'entrée plus longs que width, TextWrapper garantit qu'aucune ligne de sortie n'est plus longue que width caractères.

expand_tabs

(default: True) If true, then all tab characters in text will be expanded to spaces using the expandtabs() method of text.

tabsize

(par défaut : 8) Si expand_tabs est vrai, alors tous les caractères de tabulation dans text sont transformés en zéro ou plus d'espaces, selon la colonne courante et la taille de tabulation donnée.

Ajouté dans la version 3.3.

replace_whitespace

(par défaut : True) Si vrai, après l'expansion des tabulations mais avant le formatage, la méthode wrap() remplace chaque blanc par une espace unique. Les blancs remplacés sont les suivants : tabulation, nouvelle ligne, tabulation verticale, saut de page et retour chariot ('\t\n\v\f\r').

Note

Si expand_tabs est False et replace_whitespace est vrai, chaque caractère de tabulation est remplacé par une espace unique, ce qui n'est pas la même chose que l'extension des tabulations.

Note

Si replace_whitespace est faux, de nouvelles lignes peuvent apparaître au milieu d'une ligne et provoquer une sortie étrange. Pour cette raison, le texte doit être divisé en paragraphes (en utilisant str.splitlines() ou similaire) qui sont formatés séparément.

drop_whitespace

(par défaut : True) Si True, l'espace au début et à la fin de chaque ligne (après le formatage mais avant l'indentation) est supprimée. L'espace au début du paragraphe n'est cependant pas supprimée si elle n'est pas suivie par une espace. Si les espaces en cours de suppression occupent une ligne entière, la ligne entière est supprimée.

initial_indent

(par défaut : '') Chaîne qui est ajoutée à la première ligne de la sortie formatée. Elle compte pour le calcul de la longueur de la première ligne. La chaîne vide n'est pas indentée.

subsequent_indent

(par défaut : '') Chaîne qui préfixe toutes les lignes de la sortie formatée sauf la première. Elle compte pour le calcul de la longueur de chaque ligne à l'exception de la première.

fix_sentence_endings

(default: False) If true, TextWrapper attempts to detect sentence endings and ensure that sentences are always separated by exactly two spaces. This is generally desired for text in a monospaced font. However, the sentence detection algorithm is imperfect: it assumes that a sentence ending consists of a lowercase letter followed by one of '.', '!', or '?', possibly followed by one of '"' or "'", followed by a space. One problem with this algorithm is that it is unable to detect the difference between "Dr." in

[...] Dr. Frankenstein's monster [...]

et "Spot." dans

[...] See Spot. See Spot run [...]

fix_sentence_endings est False par défaut.

Étant donné que l'algorithme de détection de phrases repose sur string.lowercase pour la définition de « lettres minuscules » et sur une convention consistant à utiliser deux espaces après un point pour séparer les phrases sur la même ligne, ceci est spécifique aux textes de langue anglaise.

break_long_words

(par défaut : True) Si True, alors les mots plus longs que width sont cassés afin de s'assurer qu'aucune ligne ne soit plus longue que width. Si c'est False, les mots longs ne sont pas cassés et certaines lignes peuvent être plus longues que width (les mots longs seront mis sur une ligne qui leur est propre, afin de minimiser le dépassement de width).

break_on_hyphens

(par défaut : True) Si c'est vrai, le formatage se fait de préférence sur les espaces et juste après sur les traits d'union des mots composés, comme il est d'usage en anglais. Si False, seuls les espaces sont considérées comme de bons endroits pour les sauts de ligne, mais vous devez définir break_long_words à False si vous voulez des mots vraiment insécables. Le comportement par défaut dans les versions précédentes était de toujours permettre de couper les mots avec trait d'union.

max_lines

(par défaut : None) Si ce n'est pas None, alors la sortie contient au maximum max_lines lignes, avec placeholder à la fin de la sortie.

Ajouté dans la version 3.4.

placeholder

(par défaut : '' [...]') Chaîne qui apparaît à la fin du texte de sortie s'il a été tronqué.

Ajouté dans la version 3.4.

TextWrapper fournit également quelques méthodes publiques, analogues aux fonctions de commodité au niveau du module :

wrap(text)

Formate le paragraphe unique dans text (une chaîne de caractères) de sorte que chaque ligne ait au maximum width caractères. Toutes les options de formatage sont tirées des attributs d'instance de l'instance de classe TextWrapper. Renvoie une liste de lignes de sortie, sans nouvelles lignes finales. Si la sortie formatée n'a pas de contenu, la liste vide est renvoyée.

fill(text)

Formate le paragraphe unique de text et renvoie une seule chaîne contenant le paragraphe formaté.