Novedades de Python 3.9¶
- Editor
Łukasz Langa
This article explains the new features in Python 3.9, compared to 3.8. Python 3.9 was released on October 5, 2020.
Para obtener detalles completos, consulte el changelog.
Ver también
PEP 596 - Programa de lanzamiento de Python 3.9
Resumen: aspectos destacados de la versión¶
Nuevas funciones de sintaxis:
PEP 584, operadores unión agregados a
dict
;PEP 585, genéricos de sugerencia de tipo en colecciones estándar;
PEP 614, restricciones gramaticales relajadas para los decoradores.
Nuevas funciones integradas:
PEP 616, métodos de cadena para eliminar prefijos y sufijos.
Nuevas funciones en la biblioteca estándar:
PEP 593, función flexible y anotaciones variables;
Se agregó
os.pidfd_open()
que permite la gestión de procesos sin razas ni señales.
Mejoras en el intérprete:
PEP 573, acceso rápido al estado del módulo desde métodos de tipos de extensión C;
PEP 617, CPython ahora usa un nuevo analizador basado en PEG;
varias incorporaciones de Python (rango, tupla, conjunto, conjunto frozenset, lista, dict) ahora se aceleran usando PEP 590 vectorcall;
la recolección de basura no bloquea los objetos resucitados;
varios módulos de Python (
_abc
,audioop
,_bz2
,_codecs
,_contextvars
,_crypt
,_functools
,_json
,_locale
,math
,operator
,resource
,time
,_weakref
) ahora utilizan la inicialización multifase según lo definido por PEP 489;varios módulos de biblioteca estándar (
audioop
,ast
,grp
,_hashlib
,pwd
,_posixsubprocess
,random
,select
,struct
,termios
,zlib
) ahora utilizan la ABI estable definida por PEP 384.
Nuevos módulos de biblioteca:
PEP 615, la base de datos de zona horaria de IANA ahora está presente en la biblioteca estándar en el módulo
zoneinfo
;ahora se proporciona una implementación de una especie de gráfico topológico en el nuevo módulo
graphlib
.
Cambios en el proceso de lanzamiento:
PEP 602, CPython adopta un ciclo de lanzamiento anual.
Debe verificar DeprecationWarning en su código¶
Cuando todavía se admitía Python 2.7, se conservaba una gran cantidad de funciones en Python 3 por compatibilidad con versiones anteriores de Python 2.7. Con el fin de la compatibilidad con Python 2, estas capas de compatibilidad con versiones anteriores se eliminaron o se eliminarán pronto. La mayoría de ellos emitió una advertencia DeprecationWarning
durante varios años. Por ejemplo, usar collections.Mapping
en lugar de collections.abc.Mapping
emite un DeprecationWarning
desde Python 3.3, lanzado en 2012.
Pruebe su aplicación con la opción de línea de comandos -W
default
para ver DeprecationWarning
y PendingDeprecationWarning
, o incluso con -W
error
para tratarlos como errores. Warnings Filter se puede utilizar para ignorar las advertencias del código de terceros.
Python 3.9 es la última versión que proporciona esas capas de compatibilidad con versiones anteriores de Python 2, para dar más tiempo a los mantenedores de proyectos de Python para organizar la eliminación del soporte de Python 2 y agregar soporte para Python 3.9.
Los alias de Abstract Base Classes en el módulo collections
, como el alias de collections.Mapping
de collections.abc.Mapping
, se mantienen para una última versión por compatibilidad con versiones anteriores. Se eliminarán de Python 3.10.
De manera más general, intente ejecutar sus pruebas en el Python Development Mode, lo que ayuda a preparar su código para que sea compatible con la próxima versión de Python.
Nota: también se eliminaron varias obsoletas en esta versión de Python. Consulte la sección Remoto.
Nuevas características¶
Operadores de combinación y actualización de diccionarios¶
Los operadores de fusión (|
) y actualización (|=
) se han agregado a la clase dict
incorporada. Estos complementan los métodos dict.update
y {**d1, **d2}
existentes para fusionar diccionarios.
Ejemplo:
>>> x = {"key1": "value1 from x", "key2": "value2 from x"}
>>> y = {"key2": "value2 from y", "key3": "value3 from y"}
>>> x | y
{'key1': 'value1 from x', 'key2': 'value2 from y', 'key3': 'value3 from y'}
>>> y | x
{'key2': 'value2 from x', 'key3': 'value3 from y', 'key1': 'value1 from x'}
Consulte PEP 584 para obtener una descripción completa. (Contribuido por Brandt Bucher en bpo-36144.)
Nuevos métodos de cadena para eliminar prefijos y sufijos¶
Se han agregado str.removeprefix(prefix)
y str.removesuffix(suffix)
para eliminar fácilmente un prefijo o sufijo innecesario de una cadena. También se han agregado los métodos correspondientes bytes
, bytearray
y collections.UserString
. Consulte PEP 616 para obtener una descripción completa. (Contribuido por Dennis Sweeney en bpo-39939.)
Tipos genéricos de sugerencia en colecciones estándar¶
En las anotaciones de tipo, ahora puede usar tipos de colección integrados como list
y dict
como tipos genéricos en lugar de importar los tipos en mayúsculas correspondientes (por ejemplo, List
o Dict
) desde typing
. Algunos otros tipos de la biblioteca estándar ahora también son genéricos, por ejemplo, queue.Queue
.
Ejemplo:
def greet_all(names: list[str]) -> None:
for name in names:
print("Hello", name)
Consulte PEP 585 para obtener más detalles. (Contribuido por Guido van Rossum, Ethan Smith y Batuhan Taşkaya en bpo-39481.)
Nuevo analizador¶
Python 3.9 usa un nuevo analizador, basado en PEG en lugar de LL(1). El rendimiento del analizador nuevo es aproximadamente comparable al del analizador anterior, pero el formalismo PEG es más flexible que LL (1) cuando se trata de diseñar nuevas funciones de lenguaje. Comenzaremos a usar esta flexibilidad en Python 3.10 y versiones posteriores.
El módulo ast
usa el nuevo analizador y produce el mismo AST que el analizador anterior.
En Python 3.10, el analizador anterior se eliminará y también lo hará toda la funcionalidad que depende de él (principalmente el módulo parser
, que ha estado en desuso durante mucho tiempo). En Python 3.9 only, puede volver al analizador LL (1) utilizando un modificador de línea de comando (-X oldparser
) o una variable de entorno (PYTHONOLDPARSER=1
).
Consulte PEP 617 para obtener más detalles. (Contribuido por Guido van Rossum, Pablo Galindo y Lysandros Nikolaou en bpo-40334.)
Otros cambios de idioma¶
__import__()
ahora lanzaImportError
en lugar deValueError
, que solía ocurrir cuando una importación relativa pasaba de su paquete de nivel superior. (Contribuido por Ngalim Siregar en bpo-37444.)Python ahora obtiene la ruta absoluta del nombre de archivo del script especificado en la línea de comando (por ejemplo:
python3 script.py
): el módulo `` __file__`` attribute of the__main__
se convirtió en una ruta absoluta, en lugar de una ruta relativa. Estas rutas ahora siguen siendo válidas después de que las tramas del móduloos.chdir()
. Como efecto alterno, la traza también muestra la ruta absoluta para los marcos del módulo__main__
en este caso. (Contribuido por Victor Stinner en bpo-20443.)En Python Development Mode y en debug build, los argumentos de encoding and errors ahora se comprueban para las operaciones de codificación y decodificación de cadenas. Ejemplos:
open()
,str.encode()
ybytes.decode()
.De forma predeterminada, para un mejor rendimiento, el argumento errors argument is only checked at the first encoding/decoding error and the encoding a veces se ignora para cadenas vacías. (Contribuido por Victor Stinner en bpo-37388.)
"".replace("", s, n)
ahora devuelves
en lugar de una cadena vacía para todos losn
distintos de cero. Ahora es compatible con"".replace("", s)
. Hay cambios similares para los objetosbytes
ybytearray
. (Contribuido por Serhiy Storchaka en bpo-28029.)Cualquier expresión válida ahora se puede utilizar como decorator. Anteriormente, la gramática era mucho más restrictiva. Consulte PEP 614 para obtener más detalles. (Contribuido por Brandt Bucher en bpo-39702.)
Ayuda mejorada para el módulo
typing
. Las cadenas de documentos ahora se muestran para todas las formas especiales y alias genéricos especiales (comoUnion
yList
). El uso dehelp()
con un alias genérico comoList[int]
mostrará la ayuda para el tipo concreto correspondiente (list
en este caso). (Contribuido por Serhiy Storchaka en bpo-40257.)La ejecución en paralelo de
aclose()
/asend()
/athrow()
ahora está prohibida, yag_running
ahora refleja el estado de ejecución real del generador asíncrono. (Contribuido por Yury Selivanov en bpo-30773.)Los errores inesperados al llamar al método
__iter__
ya no están enmascarados porTypeError
en el operadorin
y funcionescontains()
,indexOf()
ycountOf()
del módulooperator
. (Contribuido por Serhiy Storchaka en bpo-40824.)Las expresiones lambda sin paréntesis ya no pueden ser la parte de expresión en una cláusula
if
en comprensiones y expresiones generadoras. Consulte bpo-41848 y bpo-43755 para obtener más detalles.
Nuevos módulos¶
zoneinfo¶
El módulo zoneinfo
brinda soporte para la base de datos de zona horaria de IANA a la biblioteca estándar. Agrega zoneinfo.ZoneInfo
, una implementación de datetime.tzinfo
concreta respaldada por los datos de la zona horaria del sistema.
Ejemplo:
>>> from zoneinfo import ZoneInfo
>>> from datetime import datetime, timedelta
>>> # Daylight saving time
>>> dt = datetime(2020, 10, 31, 12, tzinfo=ZoneInfo("America/Los_Angeles"))
>>> print(dt)
2020-10-31 12:00:00-07:00
>>> dt.tzname()
'PDT'
>>> # Standard time
>>> dt += timedelta(days=7)
>>> print(dt)
2020-11-07 12:00:00-08:00
>>> print(dt.tzname())
PST
Como fuente de datos alternativa para las plataformas que no envían la base de datos de la IANA, el módulo tzdata
se lanzó como un paquete propio, distribuido a través de PyPI y mantenido por el equipo central de CPython.
Ver también
- PEP 615: compatibilidad con la base de datos de zona horaria de IANA en la biblioteca estándar
PEP escrito e implementado por Paul Ganssle
Graphlib¶
Se agregó un nuevo módulo, graphlib
, que contiene la clase graphlib.TopologicalSorter
para ofrecer funcionalidad para realizar la clasificación topológica de gráficos. (Contribuido por Pablo Galindo, Tim Peters y Larry Hastings en bpo-17005.)
Módulos mejorados¶
ast¶
Se agregó la opción indent a dump()
que le permite producir una salida con sangría de varias líneas. (Contribuido por Serhiy Storchaka en bpo-37995.)
Se agregó ast.unparse()
como una función en el módulo ast
que se puede usar para descomprimir un objeto ast.AST
y producir una cadena con código que produciría un objeto ast.AST
equivalente cuando se analiza. (Contribuido por Pablo Galindo y Batuhan Taskaya en bpo-38870.)
Se agregaron cadenas de documentación a los nodos AST que contienen la firma ASDL utilizada para construir ese nodo. (Contribuido por Batuhan Taskaya en bpo-39638.)
asyncio¶
Debido a importantes problemas de seguridad, el parámetro reuse_address de asyncio.loop.create_datagram_endpoint()
ya no es compatible. Esto se debe al comportamiento de la opción de socket SO_REUSEADDR
en UDP. Para obtener más detalles, consulte la documentación de loop.create_datagram_endpoint()
. (Contribuido por Kyle Stanley, Antoine Pitrou y Yury Selivanov en bpo-37228.)
Se agregó un nuevo coroutine shutdown_default_executor()
que programa un apagado para el ejecutor predeterminado que espera en el ThreadPoolExecutor
para finalizar el cierre. Además, asyncio.run()
se ha actualizado para utilizar el nuevo coroutine. (Contribuido por Kyle Stanley en bpo-34037.)
Se agregó asyncio.PidfdChildWatcher
, una implementación de observador de niños específica de Linux que sondea los descriptores de archivos de proceso. (bpo-38692)
Se agregó un nuevo coroutine asyncio.to_thread()
. Se utiliza principalmente para ejecutar funciones vinculadas a IO en un hilo separado para evitar bloquear el bucle de eventos, y esencialmente funciona como una versión de alto nivel de run_in_executor()
que puede tomar directamente argumentos de palabras clave. (Contribuido por Kyle Stanley y Yury Selivanov en bpo-32309.)
Al cancelar la tarea debido a un tiempo de espera, asyncio.wait_for()
ahora esperará hasta que se complete la cancelación también en el caso de que timeout sea <= 0, como ocurre con los tiempos de espera positivos. (Contribuido por Elvis Pranskevichus en bpo-32751.)
asyncio
ahora lanza TyperError
al llamar a métodos incompatibles con un socket ssl.SSLSocket
. (Contribuido por Ido Michael en bpo-37404.)
compilar todo¶
Se agregó una nueva posibilidad de usar enlaces duros para archivos .pyc
duplicados: parámetro hardlink_dupes y opción de línea de comando –hardlink-dupes. (Contribuido por Lumír “Frenzy” Balhar en bpo-40495.)
Se agregaron nuevas opciones para la manipulación de rutas en los archivos .pyc
resultantes: parámetros stripdir, prependdir, limit_sl_dest y opciones de línea de comando -s, -p, -e. Se agregó la posibilidad de especificar la opción para un nivel de optimización varias veces. (Contribuido por Lumír “Frenzy” Balhar en bpo-38112.)
Futuros concurrentes¶
Se agregó un nuevo parámetro cancel_futures a concurrent.futures.Executor.shutdown()
que cancela todos los futuros pendientes que no han comenzado a ejecutarse, en lugar de esperar a que se completen antes de apagar el ejecutor. (Contribuido por Kyle Stanley en bpo-39349.)
Se eliminaron los subprocesos del demonio de ThreadPoolExecutor
y ProcessPoolExecutor
. Esto mejora la compatibilidad con los subinterpretadores y la previsibilidad en sus procesos de cierre. (Contribuido por Kyle Stanley en bpo-39812.)
Los trabajadores en ProcessPoolExecutor
ahora se generan a pedido, solo cuando no hay trabajadores inactivos disponibles para reutilizar. Esto optimiza la sobrecarga de inicio y reduce la cantidad de tiempo de CPU perdido para los trabajadores inactivos. (Contribuido por Kyle Stanley en bpo-39207.)
maldiciones¶
Se agregaron funciones curses.get_escdelay()
, curses.set_escdelay()
, curses.get_tabsize()
y curses.set_tabsize()
. (Contribuido por Anthony Sottile en bpo-38312.)
fecha y hora¶
Los métodos isocalendar()
de datetime.date
y isocalendar()
de datetime.datetime
ahora devuelven un namedtuple()
en lugar de un tuple
. (Contribuido por Dong-hee Na en bpo-24416.)
distutils¶
El comando: command: upload ahora crea resúmenes de hash SHA2-256 y Blake2b-256. Omite MD5 en plataformas que bloquean el resumen de MD5. (Contribuido por Christian Heimes en bpo-40698.)
fcntl¶
Se agregaron las constantes F_OFD_GETLK
, F_OFD_SETLK
y F_OFD_SETLKW
. (Contribuido por Dong-hee Na en bpo-38602.)
ftplib¶
FTP
y FTP_TLS
ahora lanzan un ValueError
si el tiempo de espera dado para su constructor es cero para evitar la creación de un socket sin bloqueo. (Contribuido por Dong-hee Na en bpo-39259.)
GC¶
Cuando el recolector de basura realiza una recolección en la que resucitan algunos objetos (se puede acceder a ellos desde fuera de los ciclos aislados después de que se hayan ejecutado los finalizadores), no bloquee la recolección de todos los objetos que aún no se pueden alcanzar. (Contribuido por Pablo Galindo y Tim Peters en bpo-38379.)
Se agregó una nueva función gc.is_finalized()
para verificar si el recolector de basura ha finalizado un objeto. (Contribuido por Pablo Galindo en bpo-39322.)
hashlib¶
El módulo hashlib
ahora puede usar hashes SHA3 y SHAKE XOF de OpenSSL cuando esté disponible. (Contribuido por Christian Heimes en bpo-37630.)
Los módulos hash incorporados ahora pueden desactivarse con ./configure --without-builtin-hashlib-hashes
o activarse selectivamente con p. Ej. ./configure --with-builtin-hashlib-hashes=sha3,blake2
para forzar el uso de la implementación basada en OpenSSL. (Contribuido por Christian Heimes en bpo-40479)
http¶
Los códigos de estado HTTP 103 EARLY_HINTS
, 418 IM_A_TEAPOT
y 425 TOO_EARLY
se agregan a http.HTTPStatus
. (Contribuido por Dong-hee Na en bpo-39509 y Ross Rhodes en bpo-39507.)
IDLE e idlelib¶
Opción agregada para apagar el cursor parpadeando. (Contribuido por Zackery Spytz en bpo-4603.)
La tecla Escape ahora cierra las ventanas de finalización IDLE. (Contribuido por Johnny Najera en bpo-38944.)
Se agregaron palabras clave a la lista de finalización del nombre del módulo. (Contribuido por Terry J. Reedy en bpo-37765.)
New in 3.9 maintenance releases
Make IDLE invoke sys.excepthook()
(when started without “-n”).
User hooks were previously ignored. (Contributed by Ken Hilton in
bpo-43008.)
Los cambios anteriores se han actualizado a las versiones de mantenimiento 3.8.
Rearrange the settings dialog. Split the General tab into Windows and Shell/Ed tabs. Move help sources, which extend the Help menu, to the Extensions tab. Make space for new options and shorten the dialog. The latter makes the dialog better fit small screens. (Contributed by Terry Jan Reedy in bpo-40468.) Move the indent space setting from the Font tab to the new Windows tab. (Contributed by Mark Roseman and Terry Jan Reedy in bpo-33962.)
Apply syntax highlighting to .pyi
files. (Contributed by Alex
Waygood and Terry Jan Reedy in bpo-45447.)
imaplib¶
IMAP4
y IMAP4_SSL
ahora tienen un parámetro timeout parameter for their constructors. También el método open()
ahora tiene un parámetro opcional timeout con este cambio. Los métodos anulados de IMAP4_SSL
y IMAP4_stream
se aplicaron a este cambio. (Contribuido por Dong-hee Na en bpo-38615.)
Se agrega imaplib.IMAP4.unselect()
. imaplib.IMAP4.unselect()
libera los recursos del servidor asociados con el buzón de correo seleccionado y devuelve el servidor al estado autenticado. Este comando realiza las mismas acciones que imaplib.IMAP4.close()
, excepto que ningún mensaje se elimina permanentemente del buzón de correo seleccionado actualmente. (Contribuido por Dong-hee Na en bpo-40375.)
importlib¶
Para mejorar la coherencia con las declaraciones de importación, importlib.util.resolve_name()
ahora lanza ImportError
en lugar de ValueError
para intentos de importación relativa no válidos. (Contribuido por Ngalim Siregar en bpo-37444.)
Los cargadores de importación que publican objetos de módulo inmutables ahora pueden publicar paquetes inmutables además de módulos individuales. (Contribuido por Dino Viehland en bpo-39336.)
Se agregó la función importlib.resources.files()
con soporte para subdirectorios en los datos del paquete, compatible con el backport en importlib_resources
versión 1.5. (Contribuido por Jason R. Coombs en bpo-39791.)
importlib.metadata
actualizado de importlib_metadata
versión 1.6.1.
inspeccionar¶
inspect.BoundArguments.arguments
se cambia de OrderedDict
a dictado regular. (Contribuido por Inada Naoki en bpo-36350 y bpo-39775.)
dirección IP¶
ipaddress
ahora admite direcciones de ámbito IPv6 (dirección IPv6 con sufijo %<scope_id>
).
Las direcciones IPv6 con alcance se pueden analizar mediante ipaddress.IPv6Address
. Si está presente, la identificación de la zona del alcance está disponible a través del atributo scope_id
. (Contribuido por Oleksandr Pavliuk en bpo-34788.)
A partir de Python 3.9.5, el módulo ipaddress
ya no acepta ceros a la izquierda en cadenas de direcciones IPv4. (Contribuido por Christian Heimes en bpo-36384).
Matemáticas¶
Se amplió la función math.gcd()
para manejar múltiples argumentos. Anteriormente, solo respaldaba dos argumentos. (Contribuido por Serhiy Storchaka en bpo-39648.)
math.lcm()
agregado: devuelve el mínimo común múltiplo de argumentos especificados. (Contribuido por Mark Dickinson, Ananthakrishnan y Serhiy Storchaka en bpo-39479 y bpo-39648.)
math.nextafter()
agregado: devuelve el siguiente valor de punto flotante después de x towards y. (Contribuido por Victor Stinner en bpo-39288.)
math.ulp()
agregado: devuelve el valor del bit menos significativo de un flotador. (Contribuido por Victor Stinner en bpo-39310.)
multiprocesamiento¶
La clase multiprocessing.SimpleQueue
tiene un nuevo método close()
para cerrar explícitamente la cola. (Contribuido por Victor Stinner en bpo-30966.)
nntplib¶
NNTP
y NNTP_SSL
ahora lanzan un ValueError
si el tiempo de espera dado para su constructor es cero para evitar la creación de un socket sin bloqueo. (Contribuido por Dong-hee Na en bpo-39259.)
os¶
Se agregaron CLD_KILLED
y CLD_STOPPED
para si_code
. (Contribuido por Dong-hee Na en bpo-38493.)
Se expusieron los os.pidfd_open()
(bpo-38692) y os.P_PIDFD
(bpo-38713) específicos de Linux para la gestión de procesos con descriptores de archivos.
La función os.unsetenv()
ahora también está disponible en Windows. (Contribuido por Victor Stinner en bpo-39413.)
Las funciones os.putenv()
y os.unsetenv()
ahora están siempre disponibles. (Contribuido por Victor Stinner en bpo-39395.)
Función os.waitstatus_to_exitcode()
agregada: convierte un estado de espera en un código de salida. (Contribuido por Victor Stinner en bpo-40094.)
Pathlib¶
Se agregó pathlib.Path.readlink()
que actúa de manera similar a os.readlink()
. (Contribuido por Girts Folkmanis en bpo-30618)
pdb¶
En Windows, ahora Pdb
es compatible con ~/.pdbrc
. (Contribuido por Tim Hopper y Dan Lidral-Porter en bpo-20523.)
poplib¶
POP3
y POP3_SSL
ahora lanzan un ValueError
si el tiempo de espera dado para su constructor es cero para evitar la creación de un socket sin bloqueo. (Contribuido por Dong-hee Na en bpo-39259.)
pprint¶
pprint
ahora puede imprimir types.SimpleNamespace
de forma bonita. (Contribuido por Carl Bordum Hansen en bpo-37376.)
Pydoc¶
La cadena de documentación ahora se muestra no solo para la clase, función, método, etc., sino para cualquier objeto que tenga su propio atributo __doc__
. (Contribuido por Serhiy Storchaka en bpo-40257.)
aleatorio¶
Se agregó un nuevo método random.Random.randbytes
: generar bytes aleatorios. (Contribuido por Victor Stinner en bpo-40286.)
señal¶
Expuso el signal.pidfd_send_signal()
específico de Linux para enviar señales a un proceso utilizando un descriptor de archivo en lugar de un pid. (bpo-38712)
smtplib¶
SMTP
y SMTP_SSL
ahora lanzan un ValueError
si el tiempo de espera dado para su constructor es cero para evitar la creación de un socket sin bloqueo. (Contribuido por Dong-hee Na en bpo-39259.)
El constructor LMTP
ahora tiene un parámetro timeout opcional. (Contribuido por Dong-hee Na en bpo-39329.)
enchufe¶
El módulo socket
ahora exporta la constante CAN_RAW_JOIN_FILTERS
en Linux 4.1 y superior. (Contribuido por Stefan Tatschner y Zackery Spytz en bpo-25780.)
El módulo de socket ahora admite el protocolo CAN_J1939
en plataformas que lo admiten. (Contribuido por Karl Ding en bpo-40291.)
El módulo de enchufe ahora tiene las funciones socket.send_fds()
y socket.recv_fds()
. (Contribuido por Joannah Nanjekye, Shinya Okano y Victor Stinner en bpo-28724.)
tiempo¶
En AIX, thread_time()
ahora se implementa con thread_cputime()
que tiene una resolución de nanosegundos, en lugar de clock_gettime(CLOCK_THREAD_CPUTIME_ID)
que tiene una resolución de 10 ms. (Contribuido por Batuhan Taskaya en bpo-40192)
sys¶
Se agregó un nuevo atributo sys.platlibdir
: nombre del directorio de biblioteca específico de la plataforma. Se utiliza para construir la ruta de la biblioteca estándar y las rutas de los módulos de extensión instalados. Es igual a "lib"
en la mayoría de las plataformas. En Fedora y SuSE, es igual a "lib64"
en plataformas de 64 bits. (Contribuido por Jan Matějek, Matěj Cepl, Charalampos Stratakis y Victor Stinner en bpo-1294959.)
Anteriormente, sys.stderr
estaba bloqueado en búfer cuando no era interactivo. Ahora stderr
tiene como valor predeterminado que siempre tenga búfer de línea. (Contribuido por Jendrik Seipp en bpo-13601.)
tracemalloc¶
Se agregó tracemalloc.reset_peak()
para establecer el tamaño máximo de los bloques de memoria rastreados al tamaño actual, para medir el pico de piezas de código específicas. (Contribuido por Huon Wilson en bpo-40630.)
mecanografía¶
PEP 593 introdujo un tipo typing.Annotated
para decorar tipos existentes con metadatos específicos del contexto y el nuevo parámetro include_extras
en typing.get_type_hints()
para acceder a los metadatos en tiempo de ejecución. (Contribuido por Till Varoquaux y Konstantin Kashin.)
unicodedata¶
La base de datos Unicode se ha actualizado a la versión 13.0.0. (bpo-39926).
venv¶
Los scripts de activación proporcionados por venv
ahora especifican su personalización de solicitud de manera consistente utilizando siempre el valor especificado por __VENV_PROMPT__
. Anteriormente, algunos scripts usaban __VENV_PROMPT__
incondicionalmente, otros solo si estaba configurado (que era el caso predeterminado) y uno usaba __VENV_NAME__
en su lugar. (Contribuido por Brett Cannon en bpo-37663.)
xml¶
Los caracteres de espacio en blanco dentro de los atributos ahora se conservan al serializar xml.etree.ElementTree
en un archivo XML. Los EOLN ya no se normalizan a «n». Este es el resultado de la discusión sobre cómo interpretar la sección 2.11 de la especificación XML. (Contribuido por Mefistotelis en bpo-39011.)
Optimizaciones¶
Optimización del idioma para la asignación de una variable temporal en las comprensiones. Ahora
for y in [expr]
en comprensiones es tan rápido como una simple asignacióny = expr
. Por ejemplo:sumas = [s para s en [0] para x en datos para s en [s + x]]
A diferencia del operador
:=
, este idioma no filtra una variable al alcance externo.(Contribuido por Serhiy Storchaka en bpo-32856.)
Manejo de señal optimizado en aplicaciones multiproceso. Si un subproceso diferente al subproceso principal recibe una señal, el bucle de evaluación del código de bytes ya no se interrumpe en cada instrucción de código de bytes para verificar si hay señales pendientes que no se pueden manejar. Solo el hilo principal del intérprete principal puede manejar señales.
Anteriormente, el ciclo de evaluación del código de bytes se interrumpía en cada instrucción hasta que el hilo principal manejaba las señales. (Contribuido por Victor Stinner en bpo-40010.)
Optimicé el módulo
subprocess
en FreeBSD usandoclosefrom()
. (Contribuido por Ed Maste, Conrad Meyer, Kyle Evans, Kubilay Kocak y Victor Stinner en bpo-38061.)PyLong_FromDouble()
is now up to 1.87x faster for values that fit intolong
. (Contributed by Sergey Fedoseev in bpo-37986.)Varias incorporaciones de Python (
range
,tuple
,set
,frozenset
,list
,dict
) ahora se aceleran mediante el protocolo de llamada vectorial PEP 590. (Contribuido por Dong-hee Na, Mark Shannon, Jeroen Demeyer y Petr Viktorin en bpo-37207.)difference_update()
optimizado para el caso en el que el otro conjunto es mucho más grande que el conjunto base. (Sugerido por Evgeny Kapun con código aportado por Michele Orrù en bpo-8425.)El asignador de objetos pequeños de Python (
obmalloc.c
) ahora permite (no más de) que una arena vacía permanezca disponible para su reutilización inmediata, sin devolverla al sistema operativo. Esto evita la paliza en bucles simples donde una arena podría crearse y destruirse de nuevo en cada iteración. (Contribuido por Tim Peters en bpo-37257.)floor division de operación flotante ahora tiene un mejor rendimiento. También se actualiza el mensaje de
ZeroDivisionError
para esta operación. (Contribuido por Dong-hee Na en bpo-39434.)La decodificación de cadenas cortas ASCII con códecs UTF-8 y ascii ahora es aproximadamente un 15% más rápida. (Contribuido por Inada Naoki en bpo-37348.)
A continuación, se muestra un resumen de las mejoras de rendimiento desde Python 3.4 hasta Python 3.9:
Python version 3.4 3.5 3.6 3.7 3.8 3.9
-------------- --- --- --- --- --- ---
Variable and attribute read access:
read_local 7.1 7.1 5.4 5.1 3.9 3.9
read_nonlocal 7.1 8.1 5.8 5.4 4.4 4.5
read_global 15.5 19.0 14.3 13.6 7.6 7.8
read_builtin 21.1 21.6 18.5 19.0 7.5 7.8
read_classvar_from_class 25.6 26.5 20.7 19.5 18.4 17.9
read_classvar_from_instance 22.8 23.5 18.8 17.1 16.4 16.9
read_instancevar 32.4 33.1 28.0 26.3 25.4 25.3
read_instancevar_slots 27.8 31.3 20.8 20.8 20.2 20.5
read_namedtuple 73.8 57.5 45.0 46.8 18.4 18.7
read_boundmethod 37.6 37.9 29.6 26.9 27.7 41.1
Variable and attribute write access:
write_local 8.7 9.3 5.5 5.3 4.3 4.3
write_nonlocal 10.5 11.1 5.6 5.5 4.7 4.8
write_global 19.7 21.2 18.0 18.0 15.8 16.7
write_classvar 92.9 96.0 104.6 102.1 39.2 39.8
write_instancevar 44.6 45.8 40.0 38.9 35.5 37.4
write_instancevar_slots 35.6 36.1 27.3 26.6 25.7 25.8
Data structure read access:
read_list 24.2 24.5 20.8 20.8 19.0 19.5
read_deque 24.7 25.5 20.2 20.6 19.8 20.2
read_dict 24.3 25.7 22.3 23.0 21.0 22.4
read_strdict 22.6 24.3 19.5 21.2 18.9 21.5
Data structure write access:
write_list 27.1 28.5 22.5 21.6 20.0 20.0
write_deque 28.7 30.1 22.7 21.8 23.5 21.7
write_dict 31.4 33.3 29.3 29.2 24.7 25.4
write_strdict 28.4 29.9 27.5 25.2 23.1 24.5
Stack (or queue) operations:
list_append_pop 93.4 112.7 75.4 74.2 50.8 50.6
deque_append_pop 43.5 57.0 49.4 49.2 42.5 44.2
deque_append_popleft 43.7 57.3 49.7 49.7 42.8 46.4
Timing loop:
loop_overhead 0.5 0.6 0.4 0.3 0.3 0.3
Estos resultados se generaron a partir del script de referencia de acceso variable en: Tools/scripts/var_access_benchmark.py
. El script de referencia muestra tiempos en nanosegundos. Los puntos de referencia se midieron en un Intel® Core™ i7-4960HQ processor que ejecuta las compilaciones de macOS de 64 bits que se encuentran en python.org.
Obsoleto¶
El comando distutils
bdist_msi
ahora está en desuso, usebdist_wheel
(paquetes de ruedas) en su lugar. (Contribuido por Hugo van Kemenade en bpo-39586.)Actualmente,
math.factorial()
acepta instancias defloat
con valores enteros no negativos (como5.0
). Sube unValueError
para flotadores no integrales y negativos. Ahora está en desuso. En futuras versiones de Python, lanzará unTypeError
para todos los flotadores. (Contribuido por Serhiy Storchaka en bpo-37315.)Los módulos
parser
ysymbol
están obsoletos y se eliminarán en futuras versiones de Python. Para la mayoría de los casos de uso, los usuarios pueden aprovechar la etapa de generación y compilación del árbol de sintaxis abstracta (AST), utilizando el móduloast
.Las funciones de la API pública de C
PyParser_SimpleParseStringFlags()
,PyParser_SimpleParseStringFlagsFilename()
,PyParser_SimpleParseFileFlags()
yPyNode_Compile()
están en desuso y se eliminarán en Python 3.10 junto con el analizador anterior.El uso de
NotImplemented
en un contexto booleano ha quedado obsoleto, ya que es casi exclusivamente el resultado de implementaciones incorrectas de comparadores ricos. Se convertirá enTypeError
en una versión futura de Python. (Contribuido por Josh Rosenberg en bpo-35712.)El módulo
random
actualmente acepta cualquier tipo hash como posible valor semilla. Desafortunadamente, no se garantiza que algunos de esos tipos tengan un valor hash determinista. Después de Python 3.9, el módulo restringirá sus semillas aNone
,int
,float
,str
,bytes
ybytearray
.Abrir el archivo
GzipFile
para escritura sin especificar el argumento mode argument is deprecated. In future Python versions it will always be opened for reading by default. Specify the mode para abrirlo para escribir y silenciar una advertencia. (Contribuido por Serhiy Storchaka en bpo-28286.)En desuso el `` split () `` method of
_tkinter.TkappType
en favor del métodosplitlist()
que tiene un comportamiento más consistente y predecible. (Contribuido por Serhiy Storchaka en bpo-38371.)El paso explícito de objetos de rutina a
asyncio.wait()
ha quedado obsoleto y se eliminará en la versión 3.11. (Contribuido por Yury Selivanov y Kyle Stanley en bpo-34790.)Los estándares binhex4 y hexbin4 ahora están en desuso. El módulo
binhex
y las siguientes funcionesbinascii
ahora están en desuso:(Contribuido por Victor Stinner en bpo-39353.)
Las clases
ast
slice
,Index
yExtSlice
se consideran obsoletas y se eliminarán en futuras versiones de Python. El propiovalue
debe utilizarse en lugar deIndex(value)
. Se debe utilizarTuple(slices, Load())
en lugar deExtSlice(slices)
. (Contribuido por Serhiy Storchaka en bpo-34822.)Las clases
ast
Suite
,Param
,AugLoad
yAugStore
se consideran obsoletas y se eliminarán en futuras versiones de Python. No fueron generados por el analizador y no aceptados por el generador de código en Python 3. (Contribuido por Batuhan Taskaya en bpo-39639 y bpo-39969 y Serhiy Storchaka en bpo-39988).Las funciones
PyEval_InitThreads()
yPyEval_ThreadsInitialized()
ahora están en desuso y se eliminarán en Python 3.11. Llamar aPyEval_InitThreads()
ahora no hace nada. GIL es inicializado porPy_Initialize()
desde Python 3.7. (Contribuido por Victor Stinner en bpo-39877.)Pasar
None
como primer argumento a la funciónshlex.split()
ha quedado obsoleto. (Contribuido por Zackery Spytz en bpo-33262.)smtpd.MailmanProxy()
ahora está en desuso porque no se puede utilizar sin un módulo externo,mailman
. (Contribuido por Samuel Colvin en bpo-35800.)El módulo
lib2to3
ahora emite unPendingDeprecationWarning
. Python 3.9 cambió a un analizador PEG (consulte PEP 617), y Python 3.10 puede incluir una nueva sintaxis de lenguaje que no es analizable por el analizador LL (1) de lib2to3. El módulolib2to3
puede eliminarse de la biblioteca estándar en una versión futura de Python. Considere alternativas de terceros como LibCST o parso. (Contribuido por Carl Meyer en bpo-40360.)El parámetro random de
random.shuffle()
ha quedado obsoleto. (Contribuido por Raymond Hettinger en bpo-40465)
Remoto¶
Se ha eliminado la versión errónea en
unittest.mock.__version__
.nntplib.NNTP
: Se han eliminado los métodosxpath()
yxgtitle()
. Estos métodos están obsoletos desde Python 3.3. Generalmente, estas extensiones no son compatibles o no están habilitadas por los administradores del servidor NNTP. Paraxgtitle()
, utilicenntplib.NNTP.descriptions()
onntplib.NNTP.description()
en su lugar. (Contribuido por Dong-hee Na en bpo-39366.)array.array
: Se han eliminado los métodostostring()
yfromstring()
. Eran alias detobytes()
yfrombytes()
, obsoletos desde Python 3.2. (Contribuido por Victor Stinner en bpo-38916.)Se ha eliminado la función
sys.callstats()
sin documentar. Desde Python 3.7, quedó obsoleto y siempre devolvióNone
. Requería una opción de compilación especialCALL_PROFILE
que ya se eliminó en Python 3.7. (Contribuido por Victor Stinner en bpo-37414.)Se han eliminado las funciones
sys.getcheckinterval()
ysys.setcheckinterval()
. Fueron obsoletos desde Python 3.2. Utilicesys.getswitchinterval()
ysys.setswitchinterval()
en su lugar. (Contribuido por Victor Stinner en bpo-37392.)Se ha eliminado la función C
PyImport_Cleanup()
. Se documentó como: «Vacíe la tabla del módulo. Solo para uso interno». (Contribuido por Victor Stinner en bpo-36710.)Se han eliminado los módulos
_dummy_thread
ydummy_threading
. Estos módulos quedaron obsoletos desde Python 3.7, que requiere compatibilidad con subprocesos. (Contribuido por Victor Stinner en bpo-37312.)Se han eliminado el alias de
aifc.openfp()
aaifc.open()
, el alias desunau.openfp()
asunau.open()
y el alias dewave.openfp()
awave.open()
. Fueron obsoletos desde Python 3.7. (Contribuido por Victor Stinner en bpo-37320.)Se ha eliminado el método
isAlive()
dethreading.Thread
. Quedó en desuso desde Python 3.8. Utiliceis_alive()
en su lugar. (Contribuido por Dong-hee Na en bpo-37804.)Se han eliminado los métodos
getchildren()
ygetiterator()
de las clasesElementTree
yElement
en el móduloElementTree
. Fueron obsoletos en Python 3.2. Utiliceiter(x)
olist(x)
en lugar dex.getchildren()
yx.iter()
olist(x.iter())
en lugar dex.getiterator()
. (Contribuido por Serhiy Storchaka en bpo-36543.)Se eliminó la antigua API
plistlib
, quedó en desuso desde Python 3.4. Utilice las funcionesload()
,loads()
,dump()
ydumps()
. Además, se eliminó el parámetro use_builtin_types; en su lugar, siempre se utilizan objetosbytes
estándar. (Contribuido por Jon Janzen en bpo-36409.)Se ha eliminado la función C
PyGen_NeedsFinalizing
. No se documentó, probó ni usó en ningún lugar dentro de CPython después de la implementación de PEP 442. Parche de Joannah Nanjekye. (Contribuido por Joannah Nanjekye en bpo-15088)base64.encodestring()
ybase64.decodestring()
, los alias obsoletos desde Python 3.1, se han eliminado: utilicebase64.encodebytes()
ybase64.decodebytes()
en su lugar. (Contribuido por Victor Stinner en bpo-39351.)La función
fractions.gcd()
se ha eliminado, está obsoleta desde Python 3.5 (bpo-22486): utilicemath.gcd()
en su lugar. (Contribuido por Victor Stinner en bpo-39350.)Se ha eliminado el parámetro buffering de
bz2.BZ2File
. Desde Python 3.0, se ignoró y su uso emitió unDeprecationWarning
. Pase un objeto de archivo abierto para controlar cómo se abre el archivo. (Contribuido por Victor Stinner en bpo-39357.)Se ha eliminado el parámetro encoding de
json.loads()
. A partir de Python 3.1, fue obsoleto e ignorado; su uso ha emitido unDeprecationWarning
desde Python 3.8. (Contribuido por Inada Naoki en bpo-39377)Las declaraciones
with (await asyncio.lock):
ywith (yield from asyncio.lock):
ya no son compatibles, utiliceasync with lock
en su lugar. Lo mismo es correcto paraasyncio.Condition
yasyncio.Semaphore
. (Contribuido por Andrew Svetlov en bpo-34793.)Se han eliminado la función
sys.getcounts()
, la opción de línea de comando-X showalloccount
y el camposhow_alloc_count
de la estructura CPyConfig
. Necesitaban una compilación especial de Python definiendo la macroCOUNT_ALLOCS
. (Contribuido por Victor Stinner en bpo-39489.)Se ha eliminado el atributo
_field_types
de la clasetyping.NamedTuple
. Quedó en desuso desde Python 3.8. En su lugar, utilice el atributo__annotations__
. (Contribuido por Serhiy Storchaka en bpo-40182.)Se ha eliminado el método
symtable.SymbolTable.has_exec()
. Quedó en desuso desde 2006 y solo devuelveFalse
cuando se llama. (Contribuido por Batuhan Taskaya en bpo-40208)Se han eliminado
asyncio.Task.current_task()
yasyncio.Task.all_tasks()
. Fueron obsoletos desde Python 3.7 y puede usarasyncio.current_task()
yasyncio.all_tasks()
en su lugar. (Contribución de Rémi Lapeyre en bpo-40967)El método
unescape()
en la clasehtml.parser.HTMLParser
se ha eliminado (quedó obsoleto desde Python 3.4).html.unescape()
debe usarse para convertir referencias de caracteres a los caracteres Unicode correspondientes.
Portar a Python 3.9¶
Esta sección enumera los cambios descritos anteriormente y otras correcciones de errores que pueden requerir cambios en su código.
Cambios en la API de Python¶
__import__()
yimportlib.util.resolve_name()
ahora lanzanImportError
donde anteriormente lanzabanValueError
. Las personas que llaman que detectan el tipo de excepción específico y son compatibles con Python 3.9 y versiones anteriores deberán detectar ambas usandoexcept (ImportError, ValueError):
.Los scripts de activación de
venv
ya no son casos especiales cuando__VENV_PROMPT__
se establece en""
.El método
select.epoll.unregister()
ya no ignora el errorEBADF
. (Contribuido por Victor Stinner en bpo-39239.)Se ha eliminado el parámetro compresslevel
bz2.BZ2File
se convirtió solo en un parámetro de llave, ya que buffering se quitó. (Contribuido por Victor Stinner en bpo-39357.)AST simplificado para suscripción. Los índices simples se representarán por su valor, los segmentos extendidos se representarán como tuplas.
Index(value)
devolverá unvalue
en sí mismo,ExtSlice(slices)
devolveráTuple(slices, Load())
. (Contribuido por Serhiy Storchaka en bpo-34822.)El módulo
importlib
ahora ignora la variable de entornoPYTHONCASEOK
cuando se utilizan las opciones de línea de comando-E
o-I
.El parámetro encoding se ha agregado a las clases
ftplib.FTP
yftplib.FTP_TLS
como un parámetro de solo palabra clave, y la codificación predeterminada se cambia de Latin-1 a UTF-8 para seguir: rfc: 2640.asyncio.loop.shutdown_default_executor()
se ha agregado aAbstractEventLoop
, lo que significa que los bucles de eventos alternativos que heredan de él deben tener definido este método. (Contribuido por Kyle Stanley en bpo-34037.)Los valores constantes de los indicadores futuros en el módulo
__future__
se actualizan para evitar la colisión con los indicadores del compilador. Anteriormente,PyCF_ALLOW_TOP_LEVEL_AWAIT
chocaba conCO_FUTURE_DIVISION
. (Contribuido por Batuhan Taskaya en bpo-39562)array('u')
ahora usawchar_t
como tipo C en lugar dePy_UNICODE
. Este cambio no afecta su comportamiento porquePy_UNICODE
es alias dewchar_t
desde Python 3.3. (Contribuido por Inada Naoki en bpo-34538.)La API
logging.getLogger()
ahora devuelve el registrador raíz cuando se le pasó el nombre'root'
, mientras que anteriormente devolvía un registrador no raíz llamado'root'
. Esto podría afectar los casos en los que el código de usuario desea explícitamente un registrador no root llamado'root'
, o crea una instancia de un registrador usandologging.getLogger(__name__)
en algún módulo de nivel superior llamado'root.py'
. (Contribuido por Vinay Sajip en bpo-37742.)El manejo de división de
PurePath
ahora devuelveNotImplemented
en lugar de lanzar unTypeError
cuando se pasa algo que no sea una instancia destr
oPurePath
. Esto permite crear clases compatibles que no hereden de esos tipos mencionados. (Contribución de Roger Aiudi en bpo-34775).A partir de Python 3.9.5, el módulo
ipaddress
ya no acepta ceros a la izquierda en las cadenas de direcciones IPv4. Los ceros iniciales son ambiguos y algunas bibliotecas los interpretan como notación octal. Por ejemplo, la función heredadasocket.inet_aton()
trata los ceros iniciales como una notación octal. La implementación glibc delinet_pton()
moderno no acepta ceros a la izquierda. (Contribuido por Christian Heimes en bpo-36384).codecs.lookup()
ahora normaliza el nombre de codificación de la misma manera queencodings.normalize_encoding()
, excepto quecodecs.lookup()
también convierte el nombre a minúsculas. Por ejemplo, el nombre de codificación"latex+latin1"
ahora está normalizado a"latex_latin1"
. (Contribuido por Jordon Xu en bpo-37751.)
Cambios en la API de C¶
Las instancias de heap-allocated types (como las creadas con
PyType_FromSpec()
y API similares) contienen una referencia a su objeto de tipo desde Python 3.8. Como se indica en los «Cambios en la API C» de Python 3.8, para la gran mayoría de los casos, no debería haber efectos secundarios, pero para los tipos que tienen una función personalizadatp_traverse
, asegúrese de que todas las funcionestp_traverse
personalizadas de los tipos asignados al montón visitan el tipo del objeto.Ejemplo:
int foo_traverse(foo_struct *self, visitproc visit, void *arg) { // Rest of the traverse function #if PY_VERSION_HEX >= 0x03090000 // This was not needed before Python 3.9 (Python issue 35810 and 40217) Py_VISIT(Py_TYPE(self)); #endif }
Si su función transversal delega en
tp_traverse
de su clase base (u otro tipo), asegúrese de quePy_TYPE(self)
se visite solo una vez. Tenga en cuenta que solo se espera que heap type visite el tipo entp_traverse
.Por ejemplo, si su función
tp_traverse
incluye:base->tp_traverse(self, visit, arg)
Luego añade:
#if PY_VERSION_HEX >= 0x03090000 // This was not needed before Python 3.9 (bpo-35810 and bpo-40217) if (base->tp_flags & Py_TPFLAGS_HEAPTYPE) { // a heap type's tp_traverse already visited Py_TYPE(self) } else { Py_VISIT(Py_TYPE(self)); } #else
(Consulte bpo-35810 y bpo-40217 para obtener más información).
Las funciones
PyEval_CallObject
,PyEval_CallFunction
,PyEval_CallMethod
yPyEval_CallObjectWithKeywords
están en desuso. UtilicePyObject_Call()
y sus variantes en su lugar. (Ver más detalles en bpo-29548.)
Cambios en el código de bytes de CPython¶
Se agregó el código de operación
LOAD_ASSERTION_ERROR
para manejar la declaraciónassert
. Anteriormente, la declaración de aserción no funcionaría correctamente si la excepciónAssertionError
estuviera siendo sombreada. (Contribuido por Zackery Spytz en bpo-34880.)El código de operación
COMPARE_OP
se dividió en cuatro instrucciones distintas:COMPARE_OP
para comparaciones enriquecidasIS_OP
para pruebas “es” y “no es”CONTAINS_OP
para pruebas “in” y “not in”JUMP_IF_NOT_EXC_MATCH
para verificar las excepciones en las declaraciones “try-except”.
(Contribuido por Mark Shannon en bpo-39156.)
Construir cambios¶
Se agregó la opción
--with-platlibdir
al scriptconfigure
: nombre del directorio de biblioteca específico de la plataforma, almacenado en el nuevo atributosys.platlibdir
. Consulte el atributosys.platlibdir
para obtener más información. (Contribuido por Jan Matějek, Matěj Cepl, Charalampos Stratakis y Victor Stinner en bpo-1294959.)Se ha eliminado la macro de compilación especial
COUNT_ALLOCS
. (Contribuido por Victor Stinner en bpo-39489.)En plataformas que no son de Windows, ahora se requieren las funciones
setenv()
yunsetenv()
para compilar Python. (Contribuido por Victor Stinner en bpo-39395.)En plataformas que no son de Windows, la creación de instaladores
bdist_wininst
ahora no es compatible oficialmente. (Consulte bpo-10945 para obtener más detalles).Al compilar Python en macOS desde la fuente,
_tkinter
ahora se vincula con marcos Tcl y Tk que no son del sistema si están instalados en/Library/Frameworks
, como había sido el caso en versiones anteriores de macOS. Si un SDK de macOS está configurado explícitamente, mediante--enable-universalsdk
o-isysroot
, solo se busca en el SDK. El comportamiento predeterminado aún se puede anular con--with-tcltk-includes
y--with-tcltk-libs
. (Contribuido por Ned Deily en bpo-34956.)Python ahora se puede construir para Windows 10 ARM64. (Contribuido por Steve Dower en bpo-33125.)
Algunas pruebas individuales ahora se omiten cuando se usa
--pgo
. Las pruebas en cuestión aumentaron significativamente el tiempo de la tarea PGO y probablemente no ayudaron a mejorar la optimización del ejecutable final. Esto acelera la tarea en un factor de aproximadamente 15 veces. La ejecución del conjunto de pruebas unitarias completo es lenta. Este cambio puede resultar en una compilación ligeramente menos optimizada ya que no se ejecutarán tantas ramas de código. Si está dispuesto a esperar la compilación mucho más lenta, el comportamiento anterior se puede restaurar usando./configure [..] PROFILE_TASK="-m test --pgo-extended"
. No garantizamos qué conjunto de tareas de PGO produce una compilación más rápida. Los usuarios interesados deben ejecutar sus propios puntos de referencia relevantes, ya que los resultados pueden depender del entorno, la carga de trabajo y la cadena de herramientas del compilador. (Consulte bpo-36044 y bpo-37707 para obtener más detalles).
Cambios en la API de C¶
Nuevas características¶
PEP 573: Se agregó
PyType_FromModuleAndSpec()
para asociar un módulo con una clase;PyType_GetModule()
yPyType_GetModuleState()
para recuperar el módulo y su estado; yPyCMethod
yMETH_METHOD
para permitir que un método acceda a la clase en la que se definió. (Contribuido por Marcel Plch y Petr Viktorin en bpo-38787.)Se agregó la función
PyFrame_GetCode()
: obtenga un código de marco. Se agregó la funciónPyFrame_GetBack()
: obtenga el siguiente marco exterior del marco. (Contribuido por Victor Stinner en bpo-40421.)Se agregó
PyFrame_GetLineNumber()
a la API C limitada. (Contribuido por Victor Stinner en bpo-40421.)Se agregaron funciones
PyThreadState_GetInterpreter()
yPyInterpreterState_Get()
para obtener el intérprete. Se agregó la funciónPyThreadState_GetFrame()
para obtener el marco actual de un estado de subproceso de Python. Se agregó la funciónPyThreadState_GetID()
: obtenga el identificador único de un estado de subproceso de Python. (Contribuido por Victor Stinner en bpo-39947.)Se agregó una nueva función pública
PyObject_CallNoArgs()
a la API de C, que llama a un objeto de Python invocable sin ningún argumento. Es la forma más eficiente de llamar a un objeto de Python invocable sin ningún argumento. (Contribuido por Victor Stinner en bpo-37194.)Cambios en la API C limitada (si se define la macro
Py_LIMITED_API
):Proporcione
Py_EnterRecursiveCall()
yPy_LeaveRecursiveCall()
como funciones regulares para la API limitada. Anteriormente, se definían como macros, pero estas macros no se compilaban con la API C limitada que no puede acceder al campoPyThreadState.recursion_depth
(la estructura es opaca en la API C limitada).PyObject_INIT()
yPyObject_INIT_VAR()
se convierten en funciones «opacas» habituales para ocultar los detalles de la implementación.
Se agrega la función
PyModule_AddType()
para ayudar a agregar un tipo a un módulo. (Contribuido por Dong-hee Na en bpo-40024.)Se agregaron las funciones
PyObject_GC_IsTracked()
yPyObject_GC_IsFinalized()
a la API pública para permitir consultar si los objetos de Python se están rastreando actualmente o si ya han sido finalizados por el recolector de basura, respectivamente. (Contribuido por Pablo Galindo Salgado en bpo-40241.)Se agregó
_PyObject_FunctionStr()
para obtener una representación de cadena fácil de usar de un objeto similar a una función. (Parche de Jeroen Demeyer en bpo-37645.)Se agregó
PyObject_CallOneArg()
para llamar a un objeto con un argumento posicional (parche de Jeroen Demeyer en bpo-37483).
Portar a Python 3.9¶
PyInterpreterState.eval_frame
(PEP 523) ahora requiere un nuevo parámetro tstate obligatorio (PyThreadState*
). (Contribuido por Victor Stinner en bpo-38500.)Módulos de extensión:
m_traverse
,m_clear
ym_free
Las funciones dePyModuleDef
ya no se llaman si el estado del módulo era solicitado pero aún no asignado. Este es el caso inmediatamente después de que se crea el módulo y antes de que se ejecute (funciónPy_mod_exec
). Más precisamente, estas funciones no se llaman si: c: member: ~ PyModuleDef.m_size es mayor que 0 y el estado del módulo (como lo devuelvePyModule_GetState()
) esNULL
.Los módulos de extensión sin estado de módulo (
m_size <= 0
) no se ven afectados.Si se llama a
Py_AddPendingCall()
en un subinterpretador, la función ahora está programada para ser llamada desde el subinterpretador, en lugar de ser llamada desde el intérprete principal. Cada subinterpretador ahora tiene su propia lista de llamadas programadas. (Contribuido por Victor Stinner en bpo-39984.)El registro de Windows ya no se usa para inicializar
sys.path
cuando se usa la opción-E
(siPyConfig.use_environment
está configurado en0
). Esto es importante al incrustar Python en Windows. (Contribuido por Zackery Spytz en bpo-8901.)La variable global
PyStructSequence_UnnamedField
ahora es una constante y se refiere a una cadena constante. (Contribuido por Serhiy Storchaka en bpo-38650.)La estructura
PyGC_Head
ahora es opaca. Solo se define en la API C interna (pycore_gc.h
). (Contribuido por Victor Stinner en bpo-40241.)Py_UNICODE_COPY
,Py_UNICODE_FILL
,PyUnicode_WSTR_LENGTH
,PyUnicode_FromUnicode()
,PyUnicode_AsUnicode()
,_PyUnicode_AsUnicode
yPyUnicode_AsUnicodeAndSize()
están marcados como obsoletos en C. Han sido obsoletos por PEP 393 desde Python 3.3. (Contribuido por Inada Naoki en bpo-36346.)La función
Py_FatalError()
se reemplaza con una macro que registra automáticamente el nombre de la función actual, a menos que se defina la macroPy_LIMITED_API
. (Contribuido por Victor Stinner en bpo-39882.)El protocolo vectorcall ahora requiere que la persona que llama solo pase cadenas como nombres de palabras clave. (Consulte bpo-37540 para obtener más información).
Los detalles de implementación de una serie de macros y funciones ahora están ocultos:
La macro
PyObject_IS_GC()
se convirtió en una función.La macro
PyObject_NEW()
se convierte en un alias de la macroPyObject_New()
y la macroPyObject_NEW_VAR()
se convierte en un alias de la macroPyObject_NewVar()
. Ya no acceden directamente al miembroPyTypeObject.tp_basicsize
.La macro
PyObject_GET_WEAKREFS_LISTPTR()
se convirtió en una función: la macro accedió directamente al miembroPyTypeObject.tp_weaklistoffset
.La macro
PyObject_CheckBuffer()
se convirtió en una función: la macro accedió directamente al miembroPyTypeObject.tp_as_buffer
.PyIndex_Check()
ahora siempre se declara como una función opaca para ocultar los detalles de implementación: se eliminó la macroPyIndex_Check()
. La macro accedió directamente al miembroPyTypeObject.tp_as_number
.
(Consulte bpo-40170 para obtener más detalles).
Remoto¶
Se excluyeron las macros
PyFPE_START_PROTECT()
yPyFPE_END_PROTECT()
depyfpe.h
de la API C limitada. (Contribuido por Victor Stinner en bpo-38835.)Se ha eliminado la ranura
tp_print
de PyTypeObject. Se usó para imprimir objetos en archivos en Python 2.7 y antes. Desde Python 3.0, se ha ignorado y no se ha utilizado. (Contribuido por Jeroen Demeyer en bpo-36974.)Cambios en la API C limitada (si se define la macro
Py_LIMITED_API
):Se excluyeron las siguientes funciones de la API C limitada:
PyThreadState_DeleteCurrent()
(Contribuido por Joannah Nanjekye en bpo-37878.)_Py_CheckRecursionLimit
_Py_NewReference()
_Py_ForgetReference()
_PyTraceMalloc_NewReference()
_Py_GetRefTotal()
El mecanismo de papelera que nunca funcionó en la API C limitada.
PyTrash_UNWIND_LEVEL
Py_TRASHCAN_BEGIN_CONDITION
Py_TRASHCAN_BEGIN
Py_TRASHCAN_END
Py_TRASHCAN_SAFE_BEGIN
Py_TRASHCAN_SAFE_END
Se movieron las siguientes funciones y definiciones a la API de C interna:
_PyDebug_PrintTotalRefs()
_Py_PrintReferences()
_Py_PrintReferenceAddresses()
_Py_tracemalloc_config
_Py_AddToAllObjects()
(específico paraPy_TRACE_REFS
acumulación)
Se eliminó el gancho
_PyRuntime.getframe
y se eliminó la macro_PyThreadState_GetFrame
, que era un alias de_PyRuntime.getframe
. Solo fueron expuestos por la API C interna. También se eliminó el tipoPyThreadFrameGetter
. (Contribuido por Victor Stinner en bpo-39946.)Se eliminaron las siguientes funciones de la API de C. Llame a
PyGC_Collect()
explícitamente para borrar todas las listas libres. (Contribuido por Inada Naoki y Victor Stinner en bpo-37340, bpo-38896 y bpo-40428.)PyAsyncGen_ClearFreeLists()
PyContext_ClearFreeList()
PyDict_ClearFreeList()
PyFloat_ClearFreeList()
PyFrame_ClearFreeList()
PyList_ClearFreeList()
PyMethod_ClearFreeList()
yPyCFunction_ClearFreeList()
: se han eliminado las listas libres de objetos de método enlazados.PySet_ClearFreeList()
: la lista de conjuntos libres se ha eliminado en Python 3.4.PyTuple_ClearFreeList()
PyUnicode_ClearFreeList()
: la lista libre de Unicode se ha eliminado en Python 3.3.
Función
_PyUnicode_ClearStaticStrings()
eliminada. (Contribuido por Victor Stinner en bpo-39465.)Eliminado
Py_UNICODE_MATCH
. Ha sido obsoleto por PEP 393 y roto desde Python 3.3. En su lugar, se puede utilizar la funciónPyUnicode_Tailmatch()
. (Contribuido por Inada Naoki en bpo-36346.)Archivos de encabezado limpios de interfaces definidas pero sin implementación. Los símbolos API públicos que se eliminan son:
_PyBytes_InsertThousandsGroupingLocale
,_PyBytes_InsertThousandsGrouping
,_Py_InitializeFromArgs
,_Py_InitializeFromWideArgs
,_PyFloat_Repr
,_PyFloat_Digits
,_PyFloat_DigitsInit
,PyFrame_ExtendStack
,_PyAIterWrapper_Type
,PyNullImporter_Type
,PyCmpWrapper_Type
,PySortWrapper_Type
,PyNoArgsFunction
. (Contribuido por Pablo Galindo Salgado en bpo-39372.)
Cambios notables en Python 3.9.1¶
mecanografía¶
El comportamiento de typing.Literal
se modificó para cumplir con PEP 586 y para coincidir con el comportamiento de los verificadores de tipo estático especificados en el PEP.
Literal
ahora elimina los parámetros duplicados.Las comparaciones de igualdad entre objetos
Literal
ahora son independientes del orden.Las comparaciones de
Literal
ahora respetan los tipos. Por ejemplo,Literal[0] == Literal[False]
evaluado previamente comoTrue
. Ahora esFalse
. Para respaldar este cambio, la caché de tipos utilizada internamente ahora admite tipos diferenciados.Los objetos
Literal
ahora lanzarán una excepciónTypeError
durante las comparaciones de igualdad si alguno de sus parámetros no es hashable. Tenga en cuenta que declararLiteral
con parámetros mutables no arrojará un error:>>> from typing import Literal >>> Literal[{0}] >>> Literal[{0}] == Literal[{False}] Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: unhashable type: 'set'
(Contribuido por Yurii Karabas en bpo-42345.)
Compatibilidad con macOS 11.0 (Big Sur) y Apple Silicon Mac¶
A partir de 3.9.1, Python ahora es totalmente compatible con la construcción y ejecución en macOS 11.0 (Big Sur) y en Apple Silicon Macs (basado en la arquitectura ARM64
). Una nueva variante de compilación universal, universal2
, ahora está disponible para admitir de forma nativa tanto ARM64
como Intel 64
en un conjunto de ejecutables. Los binarios ahora también se pueden construir en versiones actuales de macOS para ser implementados en una variedad de versiones anteriores de macOS (probadas a 10.9) mientras hacen que algunas funciones y opciones más nuevas del sistema operativo estén disponibles condicionalmente según la versión del sistema operativo en uso en tiempo de ejecución («vinculación débil» ).
(Contribuido por Ronald Oussoren y Lawrence D’Anna en bpo-41100.)
Cambios notables en Python 3.9.2¶
colecciones.abc¶
collections.abc.Callable
genérico ahora aplana los parámetros de tipo, similar a lo que hace actualmente typing.Callable
. Esto significa que collections.abc.Callable[[int, str], str]
tendrá __args__
de (int, str, str)
; anteriormente esto era ([int, str], str)
. Para permitir este cambio, types.GenericAlias
ahora puede ser subclasificado, y se devolverá una subclase al subíndice el tipo collections.abc.Callable
. El código que accede a los argumentos a través de typing.get_args()
o __args__
debe tener en cuenta este cambio. Se puede emitir un DeprecationWarning
para formas no válidas de parametrizar collections.abc.Callable
que pueden haber pasado silenciosamente en Python 3.9.1. Este DeprecationWarning
se convertirá en un TypeError
en Python 3.10. (Contribuido por Ken Jin en bpo-42195.)
urllib.parse¶
Las versiones anteriores de Python permitían el uso de ;
y &
como separadores de parámetros de consulta en urllib.parse.parse_qs()
y urllib.parse.parse_qsl()
. Debido a problemas de seguridad y para cumplir con las recomendaciones más recientes del W3C, esto se ha cambiado para permitir solo una clave separadora, con &
como predeterminado. Este cambio también afecta a cgi.parse()
y cgi.parse_multipart()
ya que utilizan las funciones afectadas internamente. Para obtener más detalles, consulte su documentación respectiva. (Contribuido por Adam Goldschmidt, Senthil Kumaran y Ken Jin en bpo-42967.)