Browse Source

📝 Add Spanish translation for the Python Types Intro page (#1237)

* Spanish translation Python Types Intro page

* 📝 Fix tuple docs in Types intro

* ✏️ Fix typos and wording nitpicks

Co-authored-by: Sebastián Ramírez <[email protected]>
pull/1247/head
Camila Gutierrez 5 years ago
committed by GitHub
parent
commit
bd1e85a8d3
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      docs/en/docs/python-types.md
  2. 286
      docs/es/docs/python-types.md
  3. 1
      docs/es/mkdocs.yml
  4. 2
      docs_src/python_types/tutorial007.py

2
docs/en/docs/python-types.md

@ -194,7 +194,7 @@ You would do the same to declare `tuple`s and `set`s:
This means:
* The variable `items_t` is a `tuple`, and each of its items is an `int`.
* The variable `items_t` is a `tuple` with 3 items, an `int`, another `int`, and a `str`.
* The variable `items_s` is a `set`, and each of its items is of type `bytes`.
#### Dicts

286
docs/es/docs/python-types.md

@ -0,0 +1,286 @@
# Introducción a los Tipos de Python
**Python 3.6+** tiene soporte para <abbr title="en español, anotaciones de tipo. En inglés también se conocen como: type annotations">"type hints"</abbr> opcionales.
Estos **type hints** son una nueva sintáxis, desde Python 3.6+, que permite declarar el <abbr title="por ejemplo: str, int, float, bool">tipo</abbr> de una variable.
Usando las declaraciones de tipos para tus variables, los editores y otras herramientas pueden proveerte un soporte mejor.
Este es solo un **tutorial corto** sobre los Python type hints. Solo cubre lo mínimo necesario para usarlos con **FastAPI**... realmente es muy poco lo que necesitas.
Todo **FastAPI** está basado en estos type hints, lo que le da muchas ventajas y beneficios.
Pero, así nunca uses **FastAPI** te beneficiarás de aprender un poco sobre los type hints.
!!! note "Nota"
Si eres un experto en Python y ya lo sabes todo sobre los type hints, salta al siguiente capítulo.
## Motivación
Comencemos con un ejemplo simple:
```Python
{!../../../docs_src/python_types/tutorial001.py!}
```
Llamar este programa nos muestra el siguiente <abbr title="en español: salida">output</abbr>:
```
John Doe
```
La función hace lo siguiente:
* Toma un `first_name` y un `last_name`.
* Convierte la primera letra de cada uno en una letra mayúscula con `title()`.
* Las <abbr title="las junta como si fuesen una. Con el contenido de una después de la otra. En inlgés: concatenate.">concatena</abbr> con un espacio en la mitad.
```Python hl_lines="2"
{!../../../docs_src/python_types/tutorial001.py!}
```
### Edítalo
Es un programa muy simple.
Ahora, imagina que lo estás escribiendo desde ceros.
En algún punto habrías comenzado con la definición de la función, tenías los parámetros listos...
Pero, luego tienes que llamar "ese método que convierte la primera letra en una mayúscula".
Era `upper`? O era `uppercase`? `first_uppercase`? `capitalize`?
Luego lo intentas con el viejo amigo de los programadores, el autocompletado del editor.
Escribes el primer parámetro de la función `first_name`, luego un punto (`.`) y luego presionas `Ctrl+Space` para iniciar el autocompletado.
Tristemente, no obtienes nada útil:
<img src="https://fastapi.tiangolo.com/img/python-types/image01.png">
### Añade tipos
Vamos a modificar una única línea de la versión previa.
Vamos a cambiar exactamente este fragmento, los parámetros de la función, de:
```Python
first_name, last_name
```
a:
```Python
first_name: str, last_name: str
```
Eso es todo.
Esos son los "type hints":
```Python hl_lines="1"
{!../../../docs_src/python_types/tutorial002.py!}
```
No es lo mismo a declarar valores por defecto, como sería con:
```Python
first_name="john", last_name="doe"
```
Es algo diferente.
Estamos usando los dos puntos (`:`), no un símbolo de igual (`=`).
Añadir los type hints normalmente no cambia lo que sucedería si ellos no estuviesen presentes.
Pero ahora imagina que nuevamente estás creando la función, pero con los type hints.
En el mismo punto intentas iniciar el autocompletado con `Ctrl+Space` y ves:
<img src="https://fastapi.tiangolo.com/img/python-types/image02.png">
Con esto puedes moverte hacia abajo viendo las opciones hasta que encuentras una que te suene:
<img src="https://fastapi.tiangolo.com/img/python-types/image03.png">
## Más motivación
Mira esta función que ya tiene type hints:
```Python hl_lines="1"
{!../../../docs_src/python_types/tutorial003.py!}
```
Como el editor conoce el tipo de las variables no solo obtienes autocompletado, si no que también obtienes chequeo de errores:
<img src="https://fastapi.tiangolo.com/img/python-types/image04.png">
Ahora que sabes que tienes que arreglarlo convierte `age` a un string con `str(age)`:
```Python hl_lines="2"
{!../../../docs_src/python_types/tutorial004.py!}
```
## Declarando tipos
Acabas de ver el lugar principal para declarar los type hints. Como parámetros de las funciones.
Este es también el lugar principal en que los usarías con **FastAPI**.
### Tipos simples
Puedes declarar todos los tipos estándar de Python, no solamente `str`.
Por ejemplo, puedes usar:
* `int`
* `float`
* `bool`
* `bytes`
```Python hl_lines="1"
{!../../../docs_src/python_types/tutorial005.py!}
```
### Tipos con sub-tipos
Existen algunas estructuras de datos que pueden contener otros valores, como `dict`, `list`, `set` y `tuple`. Los valores internos pueden tener su propio tipo también.
Para declarar esos tipos y sub-tipos puedes usar el módulo estándar de Python `typing`.
Él existe específicamente para dar soporte a este tipo de type hints.
#### Listas
Por ejemplo, vamos a definir una variable para que sea una `list` compuesta de `str`.
De `typing`, importa `List` (con una `L` mayúscula):
```Python hl_lines="1"
{!../../../docs_src/python_types/tutorial006.py!}
```
Declara la variable con la misma sintáxis de los dos puntos (`:`).
Pon `List` como el tipo.
Como la lista es un tipo que permite tener un "sub-tipo" pones el sub-tipo en corchetes `[]`:
```Python hl_lines="4"
{!../../../docs_src/python_types/tutorial006.py!}
```
Esto significa: la variable `items` es una `list` y cada uno de los ítems en esta lista es un `str`.
Con esta declaración tu editor puede proveerte soporte inclusive mientras está procesando ítems de la lista.
Sin tipos el autocompletado en este tipo de estructura es casi imposible de lograr:
<img src="https://fastapi.tiangolo.com/img/python-types/image05.png">
Observa que la variable `item` es unos de los elementos en la lista `items`.
El editor aún sabe que es un `str` y provee soporte para ello.
#### Tuples y Sets
Harías lo mismo para declarar `tuple`s y `set`s:
```Python hl_lines="1 4"
{!../../../docs_src/python_types/tutorial007.py!}
```
Esto significa:
* La variable `items_t` es un `tuple` con 3 ítems, un `int`, otro `int`, y un `str`.
* La variable `items_s` es un `set` y cada uno de sus ítems es de tipo `bytes`.
#### Diccionarios (Dicts)
Para definir un `dict` le pasas 2 sub-tipos separados por comas.
El primer sub-tipo es para los keys del `dict`.
El segundo sub-tipo es para los valores del `dict`:
```Python hl_lines="1 4"
{!../../../docs_src/python_types/tutorial008.py!}
```
Esto significa:
* La variable `prices` es un `dict`:
* Los keys de este `dict` son de tipo `str` (Digamos que son el nombre de cada ítem).
* Los valores de este `dict` son de tipo `float` (Digamos que son el precio de cada ítem).
### Clases como tipos
También puedes declarar una clase como el tipo de una variable.
Digamos que tienes una clase `Person`con un nombre:
```Python hl_lines="1 2 3"
{!../../../docs_src/python_types/tutorial009.py!}
```
Entonces puedes declarar una variable que sea de tipo `Person`:
```Python hl_lines="6"
{!../../../docs_src/python_types/tutorial009.py!}
```
Una vez más tendrás todo el soporte del editor:
<img src="https://fastapi.tiangolo.com/img/python-types/image06.png">
## Modelos de Pydantic
<a href="https://pydantic-docs.helpmanual.io/" class="external-link" target="_blank">Pydantic</a> es una library de Python para llevar a cabo validación de datos.
Tú declaras la "forma" de los datos mediante clases con atributos.
Cada atributo tiene un tipo.
Luego creas un instance de esa clase con algunos valores y Pydantic validará los valores, los convertirá al tipo apropiado (si ese es el caso) y te dará un objeto con todos los datos.
Y obtienes todo el soporte del editor con el objeto resultante.
Tomado de la documentación oficial de Pydantic:
```Python
{!../../../docs_src/python_types/tutorial010.py!}
```
!!! info "Información"
Para aprender más sobre <a href="https://pydantic-docs.helpmanual.io/" class="external-link" target="_blank">Pydantic mira su documentación</a>.
**FastAPI** está todo basado en Pydantic.
Vas a ver mucho más de esto en práctica en el [Tutorial - User Guide](tutorial/index.md){.internal-link target=_blank}.
## Type hints en **FastAPI**
**FastAPI** aprovecha estos type hints para hacer varias cosas.
Con **FastAPI** declaras los parámetros con type hints y obtienes:
* **Soporte en el editor**.
* **Type checks**.
...y **FastAPI** usa las mismas declaraciones para:
* **Definir requerimientos**: desde request path parameters, query parameters, headers, bodies, dependencies, etc.
* **Convertir datos**: desde el request al tipo requerido.
* **Validar datos**: viniendo de cada request:
* Generando **errores automáticos** devueltos al cliente cuando los datos son inválidos.
* **Documentar** la API usando OpenAPI:
* que en su caso es usada por las interfaces de usuario de la documentación automática e interactiva.
Puede que todo esto suene abstracto. Pero no te preocupes que todo lo verás en acción en el [Tutorial - User Guide](tutorial/index.md){.internal-link target=_blank}.
Lo importante es que usando los tipos de Python estándar en un único lugar (en vez de añadir más clases, decorator, etc.) **FastAPI** hará mucho del trabajo por ti.
!!! info "Información"
Si ya pasaste por todo el tutorial y volviste a la sección de los tipos, una buena referencia es <a href="https://mypy.readthedocs.io/en/latest/cheat_sheet_py3.html" class="external-link" target="_blank">la "cheat sheet" de `mypy`</a>.

1
docs/es/mkdocs.yml

@ -25,6 +25,7 @@ nav:
- pt: /pt/
- zh: /zh/
- features.md
- python-types.md
markdown_extensions:
- toc:
permalink: true

2
docs_src/python_types/tutorial007.py

@ -1,5 +1,5 @@
from typing import Set, Tuple
def process_items(items_t: Tuple[int], items_s: Set[bytes]):
def process_items(items_t: Tuple[int, int, str], items_s: Set[bytes]):
return items_t, items_s

Loading…
Cancel
Save