Python Language Stampa dichiarazione vs. funzione di stampa


Esempio

In Python 2, la print è una dichiarazione:

Python 2.x 2.7
print "Hello World"
print                         # print a newline
print "No newline",           # add trailing comma to remove newline 
print >>sys.stderr, "Error"   # print to stderr
print("hello")                # print "hello", since ("hello") == "hello"
print()                       # print an empty tuple "()"
print 1, 2, 3                 # print space-separated arguments: "1 2 3"
print(1, 2, 3)                # print tuple "(1, 2, 3)"

In Python 3, print() è una funzione, con argomenti parola chiave per usi comuni:

Python 3.x 3.0
print "Hello World"              # SyntaxError
print("Hello World")
print()                          # print a newline (must use parentheses)
print("No newline", end="")      # end specifies what to append (defaults to newline)
print("Error", file=sys.stderr)  # file specifies the output buffer
print("Comma", "separated", "output", sep=",")  # sep specifies the separator
print("A", "B", "C", sep="")     # null string for sep: prints as ABC
print("Flush this", flush=True)  # flush the output buffer, added in Python 3.3
print(1, 2, 3)                   # print space-separated arguments: "1 2 3"
print((1, 2, 3))                 # print tuple "(1, 2, 3)"

La funzione di stampa ha i seguenti parametri:

print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

sep è ciò che separa gli oggetti che passi per stampare. Per esempio:

print('foo', 'bar', sep='~') # out: foo~bar
print('foo', 'bar', sep='.') # out: foo.bar

end è ciò a cui è seguita la fine della dichiarazione di stampa. Per esempio:

print('foo', 'bar', end='!') # out: foo bar!

La stampa successiva a una stampa di fine non nuova riga verrà stampata sulla stessa riga:

print('foo', end='~')
print('bar')
# out: foo~bar

Nota: per compatibilità futura, la funzione di print è disponibile anche in Python 2.6; tuttavia non può essere utilizzato a meno che l'analisi dell'istruzione di print non sia disabilitata con

from __future__ import print_function

Questa funzione ha esattamente lo stesso formato di Python 3, tranne per il fatto che manca il parametro flush .

Vedere PEP 3105 per la logica.