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¶
Improved Error Messages¶
When unpacking assignment fails due to incorrect number of variables, the error message prints the received number of values in more cases than before. (Contributed by Tushar Sadhwani in gh-122239.)
>>> x, y, z = 1, 2, 3, 4 Traceback (most recent call last): File "<stdin>", line 1, in <module> x, y, z = 1, 2, 3, 4 ^^^^^^^ ValueError: too many values to unpack (expected 3, got 4)
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.)Writes to
__debug__are now detected even if the code is optimized away by the-Ocommand line option. For example,python -O -c 'assert (__debug__ := 1)'now produces aSyntaxError. (Contributed by Irit Katriel in gh-122245.)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.)Docstrings are now removed from an optimized AST in optimization level 2. (Contributed by Irit Katriel in gh-123958.)
ctypes¶
The layout of bit fields in
StructureandUnionnow matches platform defaults (GCC/Clang or MVSC) more closely. In particular, fields no longer overlap. (Contributed by Matthias Görgens in gh-97702.)The
Structure._layout_class attribute can now be set to help match a non-default ABI. (Contributed by Petr Viktorin in gh-97702.)
dis¶
Added support for rendering full source location information of
instructions, rather than only the line number. This feature is added to the following interfaces via theshow_positionskeyword argument:This feature is also exposed via
dis --show-positions.(Contributed by Bénédikt Tran in gh-123165.)
fractions¶
Added support for converting any objects that have the
as_integer_ratio() method to a Fraction.
(Contributed by Serhiy Storchaka in gh-82017.)
http¶
Directory lists and error pages generated by the http.server
module allow the browser to apply its default dark mode.
(Contributed by Yorik Hansen in gh-123430.)
json¶
Add notes for JSON serialization errors that allow to identify the source of the error. (Contributed by Serhiy Storchaka in gh-122163.)
Enable json module to work as a script using the -m switch: python -m json.
See the JSON command-line interface documentation.
(Contributed by Trey Hunner in gh-122873.)
operator¶
Two new functions
operator.is_noneandoperator.is_not_nonehave been added, such thatoperator.is_none(obj)is equivalent toobj is Noneandoperator.is_not_none(obj)is equivalent toobj is not None. (Contributed by Raymond Hettinger and Nico Mexis in gh-115808.)
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 move files and directories:copy()copies a file or directory tree to a destination.copy_into()copies into a destination directory.move()moves a file or directory tree to a destination.move_into()moves into a destination directory.
(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.)
pickle¶
Set the default protocol version on the
picklemodule to 5. For more details, please see pickle protocols.Add notes for pickle serialization errors that allow to identify the source of the error. (Contributed by Serhiy Storchaka in gh-122213.)
symtable¶
Expose the following
symtable.Symbolmethods:(Contributed by Bénédikt Tran in gh-120029.)
unicodedata¶
The Unicode database has been updated to Unicode 16.0.0.
Optimizations¶
asyncio¶
Deprecated¶
builtins: Passing a complex number as the real or imag argument in thecomplex()constructor is now deprecated; it should only be passed as a single positional argument. (Contributed by Serhiy Storchaka in gh-109218.)os: Soft deprecateos.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.)symtable: Deprecatesymtable.Class.get_methods()due to the lack of interest. (Contributed by Bénédikt Tran in gh-119698.)
Pending Removal in Python 3.15¶
-
The undocumented
ctypes.SetPointerType()function has been deprecated since Python 3.13.
-
The obsolete and rarely used
CGIHTTPRequestHandlerhas been deprecated since Python 3.13. No direct replacement exists. Anything is better than CGI to interface a web server with a request handler.The
--cgiflag to the python -m http.server command-line interface has been deprecated since Python 3.13.
-
The
getdefaultlocale()function has been deprecated since Python 3.11. Its removal was originally planned for Python 3.13 (gh-90817), but has been postponed to Python 3.15. Usegetlocale(),setlocale(), andgetencoding()instead. (Contributed by Hugo van Kemenade in gh-111187.)
-
PurePath.is_reserved()has been deprecated since Python 3.13. Useos.path.isreserved()to detect reserved paths on Windows.
-
java_ver()has been deprecated since Python 3.13. This function is only useful for Jython support, has a confusing API, and is largely untested.
-
RLock()will take no arguments in Python 3.15. Passing any arguments has been deprecated since Python 3.14, as the Python version does not permit any arguments, but the C version allows any number of positional or keyword arguments, ignoring every argument.
-
The undocumented keyword argument syntax for creating
NamedTupleclasses (e.g.Point = NamedTuple("Point", x=int, y=int)) has been deprecated since Python 3.13. Use the class-based syntax or the functional syntax instead.The
typing.no_type_check_decorator()decorator function has been deprecated since Python 3.13. After eight years in thetypingmodule, it has yet to be supported by any major type checker.
wave:The
getmark(),setmark(), andgetmarkers()methods of theWave_readandWave_writeclasses have been deprecated since Python 3.13.
Pending Removal in Python 3.16¶
-
Bitwise inversion on boolean types,
~Trueor~Falsehas been deprecated since Python 3.12, as it produces surprising and unintuitive results (-2and-1). Usenot xinstead for the logical negation of a Boolean. In the rare case that you need the bitwise inversion of the underlying integer, convert tointexplicitly (~int(x)).
-
The
'u'format code (wchar_t) has been deprecated in documentation since Python 3.3 and at runtime since Python 3.13. Use the'w'format code (Py_UCS4) for Unicode characters instead.
-
The
ExecErrorexception has been deprecated since Python 3.14. It has not been used by any function inshutilsince Python 3.4, and is now an alias ofRuntimeError.
-
The
Class.get_methodsmethod has been deprecated since Python 3.14.
sys:The
_enablelegacywindowsfsencoding()function has been deprecated since Python 3.13. Use thePYTHONLEGACYWINDOWSFSENCODINGenvironment variable instead.
-
The undocumented and unused
TarFile.tarfileattribute has been deprecated since Python 3.13.
Pending Removal in Future Versions¶
The following APIs will be removed in the future, although there is currently no date scheduled for their removal.
argparse: Nesting argument groups and nesting mutually exclusive groups are deprecated.-
bool(NotImplemented).Generators:
throw(type, exc, tb)andathrow(type, exc, tb)signature is deprecated: usethrow(exc)andathrow(exc)instead, the single argument signature.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)Support for
__index__()and__int__()method returning non-int type: these methods will be required to return an instance of a strict subclass ofint.Support for
__float__()method returning a strict subclass offloat: these methods will be required to return an instance offloat.Support for
__complex__()method returning a strict subclass ofcomplex: these methods will be required to return an instance ofcomplex.Delegation of
int()to__trunc__()method.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.)
calendar:calendar.Januaryandcalendar.Februaryconstants are deprecated and replaced bycalendar.JANUARYandcalendar.FEBRUARY. (Contributed by Prince Roshan in gh-103636.)codeobject.co_lnotab: use thecodeobject.co_lines()method instead.-
utcnow(): usedatetime.datetime.now(tz=datetime.UTC).utcfromtimestamp(): usedatetime.datetime.fromtimestamp(timestamp, tz=datetime.UTC).
gettext: Plural value must be an integer.-
load_module()method: useexec_module()instead.cache_from_source()debug_override parameter is deprecated: use the optimization parameter instead.
-
EntryPointstuple interface.Implicit
Noneon return values.
logging: thewarn()method has been deprecated since Python 3.3, usewarning()instead.mailbox: Use of StringIO input and text mode is deprecated, use BytesIO and binary mode instead.os: Callingos.register_at_fork()in multi-threaded process.pydoc.ErrorDuringImport: A tuple value for exc_info parameter is deprecated, use an exception instance.re: 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.)sre_compile,sre_constantsandsre_parsemodules.shutil:rmtree()’s onerror parameter is deprecated in Python 3.12; use the onexc parameter instead.ssloptions and protocols:ssl.SSLContextwithout protocol argument is deprecated.ssl.SSLContext:set_npn_protocols()andselected_npn_protocol()are deprecated: use ALPN instead.ssl.OP_NO_SSL*optionsssl.OP_NO_TLS*optionsssl.PROTOCOL_SSLv3ssl.PROTOCOL_TLSssl.PROTOCOL_TLSv1ssl.PROTOCOL_TLSv1_1ssl.PROTOCOL_TLSv1_2ssl.TLSVersion.SSLv3ssl.TLSVersion.TLSv1ssl.TLSVersion.TLSv1_1
sysconfig.is_python_build()check_home parameter is deprecated and ignored.threadingmethods:threading.Condition.notifyAll(): usenotify_all().threading.Event.isSet(): useis_set().threading.Thread.isDaemon(),threading.Thread.setDaemon(): usethreading.Thread.daemonattribute.threading.Thread.getName(),threading.Thread.setName(): usethreading.Thread.nameattribute.threading.currentThread(): usethreading.current_thread().threading.activeCount(): usethreading.active_count().
unittest.IsolatedAsyncioTestCase: it is deprecated to return a value that is notNonefrom a test case.urllib.parsedeprecated functions:urlparse()insteadsplitattr()splithost()splitnport()splitpasswd()splitport()splitquery()splittag()splittype()splituser()splitvalue()to_bytes()
urllib.request:URLopenerandFancyURLopenerstyle of invoking requests is deprecated. Use newerurlopen()functions and methods.wsgiref:SimpleHandler.stdout.write()should not do partial writes.xml.etree.ElementTree: Testing the truth value of anElementis deprecated. In a future release it will always returnTrue. Prefer explicitlen(elem)orelem is not Nonetests instead.zipimport.zipimporter.load_module()is deprecated: useexec_module()instead.
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.)
Add
PyIter_NextItem()to replacePyIter_Next(), which has an ambiguous return value. (Contributed by Irit Katriel and Erlend Aasland in gh-105201.)Py_Finalize()now deletes all interned strings. This is backwards incompatible to any C-Extension that holds onto an interned string after a call toPy_Finalize()and is then reused after a call toPy_Initialize(). Any issues arising from this behavior will normally result in crashes during the exectuion of the subsequent call toPy_Initialize()from accessing uninitialized memory. To fix, use an address sanitizer to identify any use-after-free coming from an interned string and deallocate it during module shutdown. (Contribued by Eddie Elizondo in gh-113601.)Add new functions to convert C
<stdint.h>numbers from/to Pythonint:(Contributed by Victor Stinner in gh-120389.)
Add
PyBytes_Join(sep, iterable)function, similar tosep.join(iterable)in Python. (Contributed by Victor Stinner in gh-121645.)Add
Py_HashBuffer()to compute and return the hash value of a buffer. (Contributed by Antoine Pitrou and Victor Stinner in gh-122854.)Add functions to get and set the current runtime Python configuration (PEP 741):
(Contributed by Victor Stinner in gh-107954.)
Add functions to configure the Python initialization (PEP 741):
(Contributed by Victor Stinner in gh-107954.)
Add
PyType_GetBaseByToken()andPy_tp_tokenslot for easier superclass identification, which attempts to resolve the type checking issue mentioned in PEP 630 (gh-124153).
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.)asyncio.iscoroutinefunction()is deprecated and will be removed in Python 3.16, useinspect.iscoroutinefunction()instead. (Contributed by Jiahao Li and Kumar Aditya in gh-122875.)
Pending Removal in Python 3.15¶
The bundled copy of
libmpdecimal.PyImport_ImportModuleNoBlock(): usePyImport_ImportModule()instead.PyWeakref_GET_OBJECT(): usePyWeakref_GetRef()instead.PyWeakref_GetObject(): usePyWeakref_GetRef()instead.Py_UNICODE_WIDEtype: usewchar_tinstead.Py_UNICODEtype: usewchar_tinstead.Python initialization functions:
PySys_ResetWarnOptions(): clearsys.warnoptionsandwarnings.filtersinstead.Py_GetExecPrefix(): getsys.exec_prefixinstead.Py_GetPath(): getsys.pathinstead.Py_GetPrefix(): getsys.prefixinstead.Py_GetProgramFullPath(): getsys.executableinstead.Py_GetProgramName(): getsys.executableinstead.Py_GetPythonHome(): getPyConfig.homeor thePYTHONHOMEenvironment variable instead.
Pending Removal in Future Versions¶
The following APIs are deprecated and will be removed, although there is currently no date scheduled for their removal.
Py_TPFLAGS_HAVE_FINALIZE: unneeded since Python 3.8.PyErr_Fetch(): usePyErr_GetRaisedException()instead.PyErr_NormalizeException(): usePyErr_GetRaisedException()instead.PyErr_Restore(): usePyErr_SetRaisedException()instead.PyModule_GetFilename(): usePyModule_GetFilenameObject()instead.PyOS_AfterFork(): usePyOS_AfterFork_Child()instead.PySlice_GetIndicesEx(): usePySlice_Unpack()andPySlice_AdjustIndices()instead.PyUnicode_AsDecodedObject(): usePyCodec_Decode()instead.PyUnicode_AsDecodedUnicode(): usePyCodec_Decode()instead.PyUnicode_AsEncodedObject(): usePyCodec_Encode()instead.PyUnicode_AsEncodedUnicode(): usePyCodec_Encode()instead.PyUnicode_READY(): unneeded since Python 3.12PyErr_Display(): usePyErr_DisplayException()instead._PyErr_ChainExceptions(): use_PyErr_ChainExceptions1instead.PyBytesObject.ob_shashmember: callPyObject_Hash()instead.PyDictObject.ma_version_tagmember.Thread Local Storage (TLS) API:
PyThread_create_key(): usePyThread_tss_alloc()instead.PyThread_delete_key(): usePyThread_tss_free()instead.PyThread_set_key_value(): usePyThread_tss_set()instead.PyThread_get_key_value(): usePyThread_tss_get()instead.PyThread_delete_key_value(): usePyThread_tss_delete()instead.PyThread_ReInitTLS(): unneeded since Python 3.7.
Removed¶
Creating
immutable typeswith mutable bases was deprecated since 3.12 and now raises aTypeError.