Si tengo una función como esta:
def foo(name, opts={}):
pass
Y quiero agregar sugerencias de tipo a los parámetros, ¿cómo lo hago? La forma en que supuse me da un error de sintaxis:
def foo(name: str, opts={}: dict) -> str:
pass
Lo siguiente no arroja un error de sintaxis, pero no parece la forma intuitiva de manejar este caso:
def foo(name: str, opts: dict={}) -> str:
pass
No puedo encontrar nada en la typingdocumentación o en una búsqueda en Google.
Editar: no sabía cómo funcionaban los argumentos predeterminados en Python, pero por el bien de esta pregunta, mantendré los ejemplos anteriores. En general, es mucho mejor hacer lo siguiente:
def foo(name: str, opts: dict=None) -> str:
if not opts:
opts={}
pass

scalalenguaje también lo hace.Respuestas:
Tu segunda forma es correcta.
esto produce
Es cierto que no figura en PEP 484 , pero las sugerencias de tipo son una aplicación de anotaciones de funciones, que están documentadas en PEP 3107. La sección de sintaxis deja en claro que los argumentos de palabras clave funcionan con las anotaciones de funciones de esta manera.
Recomiendo encarecidamente no utilizar argumentos de palabras clave mutables. Más información aquí .
fuente
Si está usando la escritura (introducida en Python 3.5) puede usar
typing.Optional, dondeOptional[X]es equivalente aUnion[X, None]. Se utiliza para indicar queNonese permite el valor explícito de . De escribir . Opcional :fuente
=enOptional[int] = Nonecomo es la convención para los argumentos de palabras clave no-tipo-insinuado?Hace poco vi esta frase:
fuente
Noneel valor predeterminado y luego verificar dentro del método evita este problema al asignar un nuevo dict cada vez que se invoca el método.