Differences between revisions 22 and 37 (spanning 15 versions)
Revision 22 as of 2016-12-13 09:18:08
Size: 3265
Editor: slabbe
Comment: Adding export SAGE_PYTHON3=yes to checklist
Revision 37 as of 2020-09-12 07:11:42
Size: 2829
Editor: chapoton
Comment:
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
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.
Line 4: Line 3:
= Do not use xrange = ||<#FF6347>Warning: || Starting from version 9.0, the default distributed version of Sage is using Python 3. See [[Python3-Switch]] for more information.||
Line 6: Line 5:
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. = Advice on writing Python3-compatible code =
Line 8: Line 7:
In the doctests, make sure that your doctest will still work when range becomes an iterator. It is now required that the code inside sage must be Python3 code. Let us describe a few important points.
Line 10: Line 9:
= Do not use .itervalues, .iteritems or .iterkeys = == Do not use xrange ==
Line 12: Line 11:
You can either use .values, .items and .keys (that are not iterators in Python2) or add "from six import itervalues" You can use xrange only inside Cython files (*.pyx).
Line 14: Line 13:
= Do not use cmp() = == Do not use it.next() to advance iterators ==

Use instead the syntax "next(it)".

== Do not use .itervalues, .iteritems or .iterkeys ==

You can use .values, .items and .keys (that are not iterators in Python2).

== Do not use cmp() ==
Line 20: Line 27:
= Behaviour of print = == Behaviour of print ==
Line 24: Line 31:
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. SageMath code is written in Python3.
Line 28: Line 35:
The easiest way to achieve this compatibility is to always use '''print(...)''' with a single string inside the parentheses. The easiest way to achieve compatibility with Python3 is to always use '''print(...)''' with a single string inside the parentheses.
Line 32: Line 39:
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.
Here below are some instructions for going from Python 2-only print to Python 3-only print.
Line 49: Line 51:
= Author/Reviewer's checklist = == Author/Reviewer's checklist ==
Line 51: Line 53:
Check the result of the patchbot Python3 compatibility plugin (for example, see the list on the right at [[https://patchbot.sagemath.org/ticket/21996/|this patchbot report]]). Check the result of the patchbot Python3 compatibility plugins named "next_method", "oldstyle_print", "python3" and "raise_statements" (for example, see the list on the right at [[https://patchbot.sagemath.org/ticket/21996/|this patchbot report]]).
Line 67: Line 69:
from __future__ import division, absolute_import, print_function, unicode_literals from __future__ import division, absolute_import, print_function
Line 70: Line 72:
Check that this works or does not break earlier (see [[https://trac.sagemath.org/ticket/21613#comment:63|#21613#comment:63]]):
{{{
export SAGE_PYTHON3=yes & make build
}}}
The command pyflakes, when installed with pip3, is also very useful to detect incompatibilities with Python3.

Warning:

Starting from version 9.0, the default distributed version of Sage is using Python 3. See Python3-Switch for more information.

Advice on writing Python3-compatible code

It is now required that the code inside sage must be Python3 code. Let us describe a few important points.

Do not use xrange

You can use xrange only inside Cython files (*.pyx).

Do not use it.next() to advance iterators

Use instead the syntax "next(it)".

Do not use .itervalues, .iteritems or .iterkeys

You can use .values, .items and .keys (that are not iterators in Python2).

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 code is written in Python3.

In the Python 3 syntax, print is a function.

The easiest way to achieve compatibility with Python3 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.

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)

Author/Reviewer's checklist

Check the result of the patchbot Python3 compatibility plugins named "next_method", "oldstyle_print", "python3" and "raise_statements" (for example, see the list on the right at this patchbot report).

Otherwise, check Python 3 syntax errors in every file changed in the current branch:

git diff --name-only develop your-new-branch | xargs -n 1 python3 -m py_compile

Check Python 3 syntax errors in every Python file of Sage library (see this thread):

find src/sage -name '*.py' | xargs -n 1 python3 -m py_compile 

If possible, include the following imports to the modules you are adding or working on:

from __future__ import division, absolute_import, print_function

The command pyflakes, when installed with pip3, is also very useful to detect incompatibilities with Python3.

Python3-compatible code (last edited 2020-09-12 07:11:42 by chapoton)