comme l'explique xeolin, raw_input() évite les erreurs, en effet A=raw_input() précise que sera une chaine de caractères, tout ce que l'utilisateur entrera sera accepté alors que B=input() précise que B sera un nombre, une chaine de caractère produira une erreur.
Pour entrer plus dans les détails : Si on attend un nombre en entrée, mettre input() est préferable en terme de taille de stockage mais peut engendrer des erreurs. Mettre raw_input() est une solution qui ne donnera jamais d'erreur et bien que plus gourmande en stockage, cette solution est préférable.
Un autre type d'erreur plus sournois, supposons que nous programmons une fonction qui donne le quotient de deux nombres: def quo(x;y): q=x/y return(q)
A=input() B=input()
Supposons que l'utilisateur entre A=4 et B=1 quo(A,B) sera alors 1 !!!!!
pourquoi ? parce que Python aura défini A et B comme entiers, q étant une opération sur deux entiers, python le reconnait également comme un entier, et vu que 4/3 est un nombre a virgule, python retoune la partie entiere.
La solution def quo(x,y): q=x/y return(q)
A=input() A=float(A) B=input() B=float(B)
print(quo(A,B))
python retournera 1.3333333
Conclusion : toujours faire attention a la declaration des variables en python, même s'il gere tres bien les variables dans la majorite des cas, il ne faut pas lui faire confiance aveuglément.
Si on sait qu'on a un nombre en entrée, on peut mettre input() seul mais il faut faire attention au type malgré tout et noter que l'entrée 1,4 donnera un erreur (1,4 <>1.4)
Personnellement, je n'utilise que raw_input() parce que je trouve préférable de définir moi même le type de mes variables.
PS : si on a répondu a ta question peux tu le signaler ?
|