|
@ -5,8 +5,8 @@ |
|
|
<em>FastAPI framework, high performance, easy to learn, fast to code, ready for production</em> |
|
|
<em>FastAPI framework, high performance, easy to learn, fast to code, ready for production</em> |
|
|
</p> |
|
|
</p> |
|
|
<p align="center"> |
|
|
<p align="center"> |
|
|
<a href="https://github.com/tiangolo/fastapi/actions?query=workflow%3ATest" target="_blank"> |
|
|
<a href="https://github.com/tiangolo/fastapi/actions?query=workflow%3ATest+event%3Apush+branch%3Amaster" target="_blank"> |
|
|
<img src="https://github.com/tiangolo/fastapi/workflows/Test/badge.svg" alt="Test"> |
|
|
<img src="https://github.com/tiangolo/fastapi/workflows/Test/badge.svg?event=push&branch=master" alt="Test"> |
|
|
</a> |
|
|
</a> |
|
|
<a href="https://codecov.io/gh/tiangolo/fastapi" target="_blank"> |
|
|
<a href="https://codecov.io/gh/tiangolo/fastapi" target="_blank"> |
|
|
<img src="https://img.shields.io/codecov/c/github/tiangolo/fastapi?color=%2334D058" alt="Coverage"> |
|
|
<img src="https://img.shields.io/codecov/c/github/tiangolo/fastapi?color=%2334D058" alt="Coverage"> |
|
@ -316,7 +316,7 @@ And now, go to <a href="http://127.0.0.1:8000/redoc" class="external-link" targe |
|
|
|
|
|
|
|
|
### Recap |
|
|
### Recap |
|
|
|
|
|
|
|
|
In summary, you declare **once** the types of parameters, body, etc. as function parameters. |
|
|
In summary, you declare **once** the types of parameters, body, etc. as function parameters. |
|
|
|
|
|
|
|
|
You do that with standard modern Python types. |
|
|
You do that with standard modern Python types. |
|
|
|
|
|
|
|
@ -373,7 +373,7 @@ Coming back to the previous code example, **FastAPI** will: |
|
|
* As the `q` parameter is declared with `= None`, it is optional. |
|
|
* As the `q` parameter is declared with `= None`, it is optional. |
|
|
* Without the `None` it would be required (as is the body in the case with `PUT`). |
|
|
* Without the `None` it would be required (as is the body in the case with `PUT`). |
|
|
* For `PUT` requests to `/items/{item_id}`, Read the body as JSON: |
|
|
* For `PUT` requests to `/items/{item_id}`, Read the body as JSON: |
|
|
* Check that it has a required attribute `name` that should be a `str`. |
|
|
* Check that it has a required attribute `name` that should be a `str`. |
|
|
* Check that it has a required attribute `price` that has to be a `float`. |
|
|
* Check that it has a required attribute `price` that has to be a `float`. |
|
|
* Check that it has an optional attribute `is_offer`, that should be a `bool`, if present. |
|
|
* Check that it has an optional attribute `is_offer`, that should be a `bool`, if present. |
|
|
* All this would also work for deeply nested JSON objects. |
|
|
* All this would also work for deeply nested JSON objects. |
|
|