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 typing
documentació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
scala
lenguaje 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 queNone
se permite el valor explícito de . De escribir . Opcional :fuente
=
enOptional[int] = None
como es la convención para los argumentos de palabras clave no-tipo-insinuado?Hace poco vi esta frase:
fuente
None
el 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.