What’s New In Python 3.14¶
- Editor:
TBD
This article explains the new features in Python 3.14, compared to 3.13.
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.14 moves towards release, so it’s worth checking back even after reading earlier versions.
Summary – Release highlights¶
New Features¶
Other Language Changes¶
Incorrect usage of
awaitand asynchronous comprehensions is now detected even if the code is optimized away by the-Ocommand line option. For example,python -O -c 'assert await 1'now produces aSyntaxError. (Contributed by Jelle Zijlstra in gh-121637.)Added class methods
float.from_number()andcomplex.from_number()to convert a number tofloatorcomplextype correspondingly. They raise an error if the argument is a string. (Contributed by Serhiy Storchaka in gh-84978.)
New Modules¶
None yet.
Improved Modules¶
ast¶
Added
ast.compare()for comparing two ASTs. (Contributed by Batuhan Taskaya and Jeremy Hylton in bpo-15987.)Add support for
copy.replace()for AST nodes.(Contributed by Bénédikt Tran in gh-121141.)
fractions¶
Added support for converting any objects that have the
as_integer_ratio() method to a Fraction.
(Contributed by Serhiy Storchaka in gh-82017.)
os¶
Added the
os.environ.refresh()method to updateos.environwith changes to the environment made byos.putenv(), byos.unsetenv(), or made outside Python in the same process. (Contributed by Victor Stinner in gh-120057.)
pathlib¶
Add methods to
pathlib.Pathto recursively copy or remove files:copy()copies the content of one file to another, likeshutil.copyfile().copytree()copies one directory tree to another, likeshutil.copytree().rmtree()recursively removes a directory tree, likeshutil.rmtree().
(Contributed by Barney Gale in gh-73991.)
pdb¶
Hard-coded breakpoints (
breakpoint()andpdb.set_trace()) now reuse the most recentPdbinstance that callsset_trace(), instead of creating a new one each time. As a result, all the instance specific data likedisplayandcommandsare preserved across hard-coded breakpoints. (Contributed by Tian Gao in gh-121450.)
symtable¶
Expose the following
symtable.Symbolmethods:(Contributed by Bénédikt Tran in gh-120029.)
pickle¶
Set the default protocol version on the
picklemodule to 5. For more details, please see pickle protocols.
Optimizations¶
asyncio¶
Deprecated¶
Passing a complex number as the real or imag argument in the
complex()constructor is now deprecated; it should only be passed as a single positional argument. (Contributed by Serhiy Storchaka in gh-109218.)Soft deprecate
os.popen()andos.spawn*functions. They should no longer be used to write new code. Thesubprocessmodule is recommended instead. (Contributed by Victor Stinner in gh-120743.)Deprecate
symtable.Class.get_methods()due to the lack of interest. (Contributed by Bénédikt Tran in gh-119698.)
Removed¶
argparse¶
Remove the type, choices, and metavar parameters of
argparse.BooleanOptionalAction. They were deprecated since 3.12.
ast¶
Remove the following classes. They were all deprecated since Python 3.8, and have emitted deprecation warnings since Python 3.12:
ast.Numast.Strast.Bytesast.NameConstantast.Ellipsis
Use
ast.Constantinstead. As a consequence of these removals, user-definedvisit_Num,visit_Str,visit_Bytes,visit_NameConstantandvisit_Ellipsismethods on customast.NodeVisitorsubclasses will no longer be called when theNodeVisitorsubclass is visiting an AST. Define avisit_Constantmethod instead.Also, remove the following deprecated properties on
ast.Constant, which were present for compatibility with the now-removed AST classes:ast.Constant.nast.Constant.s
Use
ast.Constant.valueinstead.(Contributed by Alex Waygood in gh-119562.)
asyncio¶
Remove the following classes and functions. They were all deprecated and emitted deprecation warnings since Python 3.12:
asyncio.AbstractChildWatcherasyncio.SafeChildWatcherasyncio.MultiLoopChildWatcherasyncio.FastChildWatcherasyncio.ThreadedChildWatcherasyncio.PidfdChildWatcherasyncio.AbstractEventLoopPolicy.get_child_watcher()asyncio.AbstractEventLoopPolicy.set_child_watcher()asyncio.get_child_watcher()asyncio.set_child_watcher()
(Contributed by Kumar Aditya in gh-120804.)
collections.abc¶
Remove
collections.abc.ByteString. It had previously raised aDeprecationWarningsince Python 3.12.
email¶
Remove the isdst parameter from
email.utils.localtime(). (Contributed by Hugo van Kemenade in gh-118798.)
importlib¶
Remove deprecated
importlib.abcclasses:importlib.abc.ResourceReaderimportlib.abc.Traversableimportlib.abc.TraversableResources
Use
importlib.resources.abcclasses instead:(Contributed by Jason R. Coombs and Hugo van Kemenade in gh-93963.)
itertools¶
Remove
itertoolssupport for copy, deepcopy, and pickle operations. These had previously raised aDeprecationWarningsince Python 3.12. (Contributed by Raymond Hettinger in gh-101588.)
pathlib¶
Remove support for passing additional keyword arguments to
pathlib.Path. In previous versions, any such arguments are ignored.Remove support for passing additional positional arguments to
pathlib.PurePath.relative_to()andis_relative_to(). In previous versions, any such arguments are joined onto other.
pty¶
Remove deprecated
pty.master_open()andpty.slave_open(). They had previously raised aDeprecationWarningsince Python 3.12. Usepty.openpty()instead. (Contributed by Nikita Sobolev in gh-118824.)
sqlite3¶
Remove
versionandversion_infofromsqlite3. (Contributed by Hugo van Kemenade in gh-118924.)Disallow using a sequence of parameters with named placeholders. This had previously raised a
DeprecationWarningsince Python 3.12; it will now raise asqlite3.ProgrammingError. (Contributed by Erlend E. Aasland in gh-118928 and gh-101693.)
typing¶
Remove
typing.ByteString. It had previously raised aDeprecationWarningsince Python 3.12.
urllib¶
Remove deprecated
Quoterclass fromurllib.parse. It had previously raised aDeprecationWarningsince Python 3.11. (Contributed by Nikita Sobolev in gh-118827.)
Others¶
Using
NotImplementedin a boolean context will now raise aTypeError. It had previously raised aDeprecationWarningsince Python 3.9. (Contributed by Jelle Zijlstra in gh-118767.)The
int()built-in no longer delegates to__trunc__(). Classes that want to support conversion to integer must implement either__int__()or__index__(). (Contributed by Mark Dickinson in gh-119743.)
Porting to Python 3.14¶
This section lists previously described changes and other bugfixes that may require changes to your code.
Changes in the Python API¶
functools.partialis now a method descriptor. Wrap it instaticmethod()if you want to preserve the old behavior. (Contributed by Serhiy Storchaka and Dominykas Grigonis in gh-121027.)
Build Changes¶
C API Changes¶
New Features¶
Add
PyLong_GetSign()function to get the sign ofintobjects. (Contributed by Sergey B Kirpichev in gh-116560.)Add a new
PyUnicodeWriterAPI to create a Pythonstrobject:(Contributed by Victor Stinner in gh-119182.)
Porting to Python 3.14¶
Deprecated¶
Macros
Py_IS_NAN,Py_IS_INFINITYandPy_IS_FINITEare soft deprecated, use insteadisnan,isinfandisfiniteavailable frommath.hsince C99. (Contributed by Sergey B Kirpichev in gh-119613.)
Removed¶
Creating
immutable typeswith mutable bases was deprecated since 3.12 and now raises aTypeError.