What’s New In Python 3.12¶
- Release
3.12.0a0
- Date
June 15, 2022
This article explains the new features in Python 3.12, compared to 3.11.
For full details, see the changelog.
Note
Prerelease users should be aware that this document is currently in draft form. It will be updated substantially as Python 3.12 moves towards release, so it’s worth checking back even after reading earlier versions.
Summary – Release highlights¶
Important deprecations, removals or restrictions:
PEP 623, Remove wstr from Unicode
New Features¶
Other Language Changes¶
New Modules¶
None yet.
Improved Modules¶
os¶
Add
os.PIDFD_NONBLOCKto open a file descriptor for a process withos.pidfd_open()in non-blocking mode. (Contributed by Kumar Aditya in gh-93312.)
Optimizations¶
CPython bytecode changes¶
Deprecated¶
Pending Removal in Python 3.13¶
The following modules and APIs have been deprecated in earlier Python releases, and will be removed in Python 3.13.
Modules (see PEP 594):
APIs:
Pending Removal in Future Versions¶
The following APIs were deprecated in earlier Python versions and will be removed, although there is currently no date scheduled for their removal.
Currently Python accepts numeric literals immediately followed by keywords, for example
0in x,1or x,0if 1else 2. It allows confusing and ambiguous expressions like[0x1for x in y](which can be interpreted as[0x1 for x in y]or[0x1f or x in y]). A syntax warning is raised if the numeric literal is immediately followed by one of keywordsand,else,for,if,in,isandor. In a future release it will be changed to a syntax error. (gh-87999)
Removed¶
The following undocumented
sqlite3features, deprecated in Python 3.10, are now removed:sqlite3.enable_shared_cache()sqlite3.OptimizedUnicode
(Contributed by Erlend E. Aasland in gh-92548)
The
--experimental-isolated-subinterpretersconfigure flag (and correspondingEXPERIMENTAL_ISOLATED_SUBINTERPRETERS) have been removed.
Porting to Python 3.12¶
This section lists previously described changes and other bugfixes that may require changes to your code.
Changes in the Python API¶
More strict rules are now applied for numerical group references and group names in regular expressions. Only sequence of ASCII digits is now accepted as a numerical reference. The group name in bytes patterns and replacement strings can now only contain ASCII letters and digits and underscore. (Contributed by Serhiy Storchaka in gh-91760.)
Removed randrange() functionality deprecated since Python 3.10. Formerly, randrange(10.0) losslessly converted to randrange(10). Now, it raises a TypeError. Also, the exception raised for non-integral values such as randrange(10.5) or randrange(‘10’) has been changed from ValueError to TypeError. This also prevents bugs where
randrange(1e25)would silently select from a larger range thanrandrange(10**25). (Originally suggested by Serhiy Storchaka gh-86388.)
Build Changes¶
va_start()with two parameters, likeva_start(args, format),is now required to build Python.va_start()is no longer called with a single parameter. (Contributed by Kumar Aditya in gh-93207.)
C API Changes¶
New Features¶
Added the new limited C API function
PyType_FromMetaclass(), which generalizes the existingPyType_FromModuleAndSpec()using an additional metaclass argument. (Contributed by Wenzel Jakob in gh-93012.)
Porting to Python 3.12¶
Legacy Unicode APIs based on
Py_UNICODE*representation has been removed. Please migrate to APIs based on UTF-8 orwchar_t*.Argument parsing functions like
PyArg_ParseTuple()doesn’t supportPy_UNICODE*based format (e.g.u,Z) anymore. Please migrate to other formats for Unicode likes,z,es, andU.
Deprecated¶
Removed¶
Remove the
token.hheader file. There was never any public tokenizer C API. Thetoken.hheader file was only designed to be used by Python internals. (Contributed by Victor Stinner in gh-92651.)Leagcy Unicode APIs has been removed. See PEP 623 for detail.
PyUnicode_WCHAR_KINDPyUnicode_AS_UNICODE()PyUnicode_AsUnicode()PyUnicode_AsUnicodeAndSize()PyUnicode_AS_DATA()PyUnicode_FromUnicode()PyUnicode_GET_SIZE()PyUnicode_GetSize()PyUnicode_GET_DATA_SIZE()
Remove the
PyUnicode_InternImmortal()function and theSSTATE_INTERNED_IMMORTALmacro. (Contributed by Victor Stinner in gh-85858.)