| Size: 1258 Comment: better | Size: 2272 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| ## page was renamed from PrintFunction SageMath is currently using Python2, but is moving towards Python3. To make transition possible, it is required that the code must be as compatible as possible with both Python2 and Python3. Let us describe a few important points. = Do not use xrange = You can use xrange only inside Cython files (*.pyx). If you need an iterator range, you should add "from six.moves import range" in the top import section of your *.py file. In the doctests, make sure that your doctest will still work when range becomes an iterator. = Do not use .itervalues, .iteritems or .iterkeys = You can either use .values, .items and .keys (that are not iterators in Python2) or add "from six import itervalues" = Do not use cmp() == The cmp global function is gone in Python3 and must be avoided completely. SageMath now has a "richcmp" function that can sometimes replace "cmp". | |
| Line 5: | Line 24: | 
| In version 7.2, SageMath is using the Python 2 syntax for print. Later (no schedule yet) it will switch to the Python 3 syntax, where print is a function. | SageMath interface is currently using the Python2 syntax for print, but SageMath code is written in such a way that it is also Python3 compatible. It is therefore required to use print in a way that is compatible with both Python 2 and Python 3. | 
| Line 7: | Line 26: | 
| It is therefore a good idea to try to use print in a way that is compatible with both Python 2 and Python 3. | In the Python 3 syntax, print is a function. | 
| Line 9: | Line 28: | 
| The easiest way to achieve this is to always use '''print(...)''' with a single string inside the parentheses. | The easiest way to achieve this compatibility is to always use '''print(...)''' with a single string inside the parentheses. | 
| Line 13: | Line 32: | 
| Here below are some instructions for going from Python2-only print to Python 3-only print. This can be used if you | Here below are some instructions for going from Python 2-only print to Python 3-only print. The Python 3 syntax can be used right now if you | 
| Line 22: | Line 41: | 
| Here is a conversion table to help you adapt your code: | Here is a conversion table to help you adapt your code in more complex cases: | 
SageMath is currently using Python2, but is moving towards Python3. To make transition possible, it is required that the code must be as compatible as possible with both Python2 and Python3. Let us describe a few important points.
Do not use xrange
You can use xrange only inside Cython files (*.pyx). If you need an iterator range, you should add "from six.moves import range" in the top import section of your *.py file.
In the doctests, make sure that your doctest will still work when range becomes an iterator.
Do not use .itervalues, .iteritems or .iterkeys
You can either use .values, .items and .keys (that are not iterators in Python2) or add "from six import itervalues"
= Do not use cmp() ==
The cmp global function is gone in Python3 and must be avoided completely.
SageMath now has a "richcmp" function that can sometimes replace "cmp".
Behaviour of print
The behaviour of print differs in Python 2 and in Python 3.
SageMath interface is currently using the Python2 syntax for print, but SageMath code is written in such a way that it is also Python3 compatible. It is therefore required to use print in a way that is compatible with both Python 2 and Python 3.
In the Python 3 syntax, print is a function.
The easiest way to achieve this compatibility is to always use print(...) with a single string inside the parentheses.
For example, print("He has eaten {} bananas".format(10)) will work in both Python 2 and Python 3 and give the same result.
Here below are some instructions for going from Python 2-only print to Python 3-only print. The Python 3 syntax can be used right now if you add the line
from __future__ import print_function
as the first code line of your python files.
| To convert print from Python 2 to Python 3, you basically need to add parentheses, and write print("x") instead of print "x". | 
Here is a conversion table to help you adapt your code in more complex cases:
| Python 2 | Python 3 | 
| print a | print(a) | 
| print a, b, c | print(a, b, c) | 
| print x, | print(x, end=" ") | 
| print >>sys.stderr, x | print(x, file=sys.stderr) | 
