Skip to main content

Clean single-source support for Python 3 and 2

Project description

future is the missing compatibility layer between Python 2 and Python 3. It allows you to use a single, clean Python 3.x-compatible codebase to support both Python 2 and Python 3 with minimal overhead.

It is designed to be used as follows:

from __future__ import (absolute_import, division,
                        print_function, unicode_literals)
from builtins import (
         bytes, dict, int, list, object, range, str,
         ascii, chr, hex, input, next, oct, open,
         pow, round, super,
         filter, map, zip)

followed by predominantly standard, idiomatic Python 3 code that then runs similarly on Python 2.6/2.7 and Python 3.3+.

The imports have no effect on Python 3. On Python 2, they shadow the corresponding builtins, which normally have different semantics on Python 3 versus 2, to provide their Python 3 semantics.

Standard library reorganization

future supports the standard library reorganization (PEP 3108) through the following Py3 interfaces:

>>> # Top-level packages with Py3 names provided on Py2:
>>> import html.parser
>>> import queue
>>> import tkinter.dialog
>>> import xmlrpc.client
>>> # etc.
>>> # Aliases provided for extensions to existing Py2 module names:
>>> from future.standard_library import install_aliases
>>> install_aliases()
>>> from collections import Counter, OrderedDict   # backported to Py2.6
>>> from collections import UserDict, UserList, UserString
>>> import urllib.request
>>> from itertools import filterfalse, zip_longest
>>> from subprocess import getoutput, getstatusoutput

Automatic conversion

An included script called futurize aids in converting code (from either Python 2 or Python 3) to code compatible with both platforms. It is similar to python-modernize but goes further in providing Python 3 compatibility through the use of the backported types and builtin functions in future.

Documentation

See: https://python-future.org

Credits

Author:

Ed Schofield, Jordan M. Adler, et al

Sponsor:

Python Charmers: https://pythoncharmers.com

Others:

See docs/credits.rst or https://python-future.org/credits.html

Licensing

Copyright 2013-2024 Python Charmers, Australia. The software is distributed under an MIT licence. See LICENSE.txt.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

future-1.0.0.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

future-1.0.0-py3-none-any.whl (491.3 kB view details)

Uploaded Python 3

File details

Details for the file future-1.0.0.tar.gz.

File metadata

  • Download URL: future-1.0.0.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.7

File hashes

Hashes for future-1.0.0.tar.gz
Algorithm Hash digest
SHA256 bd2968309307861edae1458a4f8a4f3598c03be43b97521076aebf5d94c07b05
MD5 028bd8af5a7dd853fd12c8bf627236a9
BLAKE2b-256 a7b24140c69c6a66432916b26158687e821ba631a4c9273c474343badf84d3ba

See more details on using hashes here.

File details

Details for the file future-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: future-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 491.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.7

File hashes

Hashes for future-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 929292d34f5872e70396626ef385ec22355a1fae8ad29e1a734c3e43f9fbc216
MD5 232c541d97f2806d143148651e8bc031
BLAKE2b-256 da71ae30dadffc90b9006d77af76b393cb9dfbfc9629f339fc1574a1c52e6806

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page