« Programmation Python/Afficher un texte » : différence entre les versions

Un livre de Wikilivres.
Contenu supprimé Contenu ajouté
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 112 : Ligne 112 :
-H hôte
-H hôte
}
}
</source>

== Commentaires ==

Une ligne commençant par un dièse (''#'') est un commentaire : elle n'est pas prise en compte par l'interpréteur. De même pour tous les caractères qui sont mis à la suite d'un dièse. Cette dernière règle ne s'applique pas lorsque le dièse est positionné dans une chaîne de caractères.

Ce texte affiché uniquement dans le code source sert à expliquer à celui qui relit le code les subtilités les moins évidentes de celui-ci.

{{Exemple|Exemple 1|On notera que la fonction ''print'' affiche son argument.|
<source lang="python">
#Toute cette ligne est un commentaire.
print("Bonjour le monde") #Ceci est également un commentaire
print("Bonjour"; print "Le monde"); #Ceci est une ligne comportant
#plusieurs instructions
print("Cette ligne ne contient pas de #commentaire")
</source>
}}

=== Les commentaires de bloc ===
Les ''block comments'' sont assurés par des triples apostrophes ou guillemets :
<source lang="python">
print('début')
'''
Le paragraphe suivant est commenté
sur plusieurs lignes
'''
print('fin')
</source>
</source>

Version du 7 mai 2017 à 00:49

Ce chapitre détaille les différentes manières d'afficher un texte en console, par exemple pour générer des logs. Les interfaces graphiques plus élaborées seront traitées avec des bibliothèques.

print()

La fonction print sert à afficher des données sur la sortie standard, qui est l’écran. Exemple :

fonction print
>>> print('Hello World!')
Hello World!

input()

input fait comme "print", mais stoppe le programme en attente que l'utilisateur presse "entrée". De plus, si on stocke son résultat une variable, elle contient le texte que l'utilisateur a tapé avant de valider. Si ce texte est vide, le programme plante. Exemple :

variable = input('Quel est votre nom ? ') # répondre avec un texte entre apostrophe
print('Bonjour ' + variable)

raw_input()

raw_input() fait comme "input", mais ne plante pas si le texte est vide.


Afficher des caractères spéciaux

Normalement, les symboles ne faisant pas partie du code ASCII sont traités comme les autres. Ex :

print('à â ç é è ê ë ï ô ù ÿ')
à â ç é è ê ë ï ô ù ÿ

Toutefois selon l'encodage, il peut être nécessaire de les convertir en Unicode en plaçant un "u" avant :

print(u'à â ç é è ê ë ï ô ù ÿ')

Pour les retours à la ligne, utiliser "\n".

Antislash

Les caractères affichés par les fonctions précédentes doivent être encadrés par des apostrophes ou des guillemets, mais que se passe-t-il s'ils contiennent eux-mêmes ces symboles ?

Testons la fonction print :

ce qui marche :
>>> print("ça marche aussi")
ça marche aussi
>>> print('et ça ? "ça marche" ou pas')
et ça ? "ça marche" ou pas
>>> print("et on 'essaye' l'inverse")
et on 'essaye' l'inverse
ce qui ne marche pas :
>>> print('un simple guillemet ' encadré par du simple quote ')
[message d'erreur]
>>> print(" pareil pour le " double ")
[message d'erreur]
>>> print("double " deux " fois dans double")
[message d'erreur]

En Python, le simple quote peut encadrer le double, et le double peut encadrer le simple, car la chaîne commence au premier guillemet et finit au même guillemet.


Pour s'affranchir de ces limitations, on utilise un caractère d'échappement, qui est, en Python, l'antislash (« \ »). Il permet quelques subtilités complémentaires :

  • En premier lieu, il permet d'écrire sur plusieurs lignes n'importe quel type de commande. Pratique pour éviter de dépasser les 120 caractères pouvant nécessiter l'utilisation d'un ascenseur latéral pour être lus.
  • À l'intérieur d'une chaîne de caractères, l’antislash permet d'insérer un certain nombre de codes spéciaux (sauts à la ligne, apostrophes, guillemets, etc.). Exemples :
>>> print('une chaîne avec des \' guillemets \' simples dans des simples, c\'est protégé ')
une chaîne avec des ' guillemets ' simples dans des simples, c'est protégé

>>> txt3 = '"N\'est-ce pas ?" répondit-elle.'
>>> print txt3
"N'est-ce pas ?" répondit-elle.

>>> Salut = "Ceci est une chaîne plutôt longue\n contenant plusieurs lignes \
... de texte (Ceci fonctionne\n de la même façon en C/C++.\n\
...     Notez que les blancs en début\n de ligne sont significatifs.\n"
>>> print Salut
Ceci est une chaîne plutôt longue
 contenant plusieurs lignes de texte (Ceci fonctionne
 de la même façon en C/C++.
    Notez que les blancs en début
 de ligne sont significatifs.

On remarque que la séquence \' permet d'insérer une apostrophe dans une chaîne délimitée par des apostrophes, et \" par des guillemets.

De même, "\\" affiche "\".


Triple quotes

Si le nombre d’antislash nuit à la lisibilité du code, on peut délimiter la chaîne à l'aide de triples guillemets ou de triples apostrophes :

>>> a1 = """
... Usage: trucmuche[OPTIONS]
... { -h
...   -H hôte
... }"""

>>> print a1

Usage: trucmuche[OPTIONS]
{ -h
  -H hôte
}

Commentaires

Une ligne commençant par un dièse (#) est un commentaire : elle n'est pas prise en compte par l'interpréteur. De même pour tous les caractères qui sont mis à la suite d'un dièse. Cette dernière règle ne s'applique pas lorsque le dièse est positionné dans une chaîne de caractères.

Ce texte affiché uniquement dans le code source sert à expliquer à celui qui relit le code les subtilités les moins évidentes de celui-ci.

#Toute cette ligne est un commentaire.
print("Bonjour le monde") #Ceci est également un commentaire
print("Bonjour"; print "Le monde"); #Ceci est une ligne comportant
#plusieurs instructions
print("Cette ligne ne contient pas de #commentaire")
Exemple 1 : On notera que la fonction print affiche son argument.


Les commentaires de bloc

Les block comments sont assurés par des triples apostrophes ou guillemets :

print('début')
'''
Le paragraphe suivant est commenté
sur plusieurs lignes
'''
print('fin')