|
|
@ -20,69 +20,13 @@ This is because uploaded files are sent as "form data". |
|
|
|
|
|
|
|
Import `File` and `UploadFile` from `fastapi`: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="3" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="1" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="1" |
|
|
|
{!> ../../docs_src/request_files/tutorial001.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial001_an_py39.py hl[3] *} |
|
|
|
|
|
|
|
## Define `File` Parameters |
|
|
|
|
|
|
|
Create file parameters the same way you would for `Body` or `Form`: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="9" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="8" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="7" |
|
|
|
{!> ../../docs_src/request_files/tutorial001.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial001_an_py39.py hl[9] *} |
|
|
|
|
|
|
|
/// info |
|
|
|
|
|
|
@ -110,35 +54,7 @@ But there are several cases in which you might benefit from using `UploadFile`. |
|
|
|
|
|
|
|
Define a file parameter with a type of `UploadFile`: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="14" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="13" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="12" |
|
|
|
{!> ../../docs_src/request_files/tutorial001.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial001_an_py39.py hl[14] *} |
|
|
|
|
|
|
|
Using `UploadFile` has several advantages over `bytes`: |
|
|
|
|
|
|
@ -221,91 +137,13 @@ This is not a limitation of **FastAPI**, it's part of the HTTP protocol. |
|
|
|
|
|
|
|
You can make a file optional by using standard type annotations and setting a default value of `None`: |
|
|
|
|
|
|
|
//// tab | Python 3.10+ |
|
|
|
|
|
|
|
```Python hl_lines="9 17" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_02_an_py310.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="9 17" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_02_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="10 18" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_02_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.10+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="7 15" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_02_py310.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="9 17" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_02.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial001_02_an_py310.py hl[9,17] *} |
|
|
|
|
|
|
|
## `UploadFile` with Additional Metadata |
|
|
|
|
|
|
|
You can also use `File()` with `UploadFile`, for example, to set additional metadata: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="9 15" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_03_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="8 14" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_03_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="7 13" |
|
|
|
{!> ../../docs_src/request_files/tutorial001_03.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial001_03_an_py39.py hl[9,15] *} |
|
|
|
|
|
|
|
## Multiple File Uploads |
|
|
|
|
|
|
@ -315,49 +153,7 @@ They would be associated to the same "form field" sent using "form data". |
|
|
|
|
|
|
|
To use that, declare a list of `bytes` or `UploadFile`: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="10 15" |
|
|
|
{!> ../../docs_src/request_files/tutorial002_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="11 16" |
|
|
|
{!> ../../docs_src/request_files/tutorial002_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.9+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="8 13" |
|
|
|
{!> ../../docs_src/request_files/tutorial002_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="10 15" |
|
|
|
{!> ../../docs_src/request_files/tutorial002.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial002_an_py39.py hl[10,15] *} |
|
|
|
|
|
|
|
You will receive, as declared, a `list` of `bytes` or `UploadFile`s. |
|
|
|
|
|
|
@ -373,49 +169,7 @@ You could also use `from starlette.responses import HTMLResponse`. |
|
|
|
|
|
|
|
And the same way as before, you can use `File()` to set additional parameters, even for `UploadFile`: |
|
|
|
|
|
|
|
//// tab | Python 3.9+ |
|
|
|
|
|
|
|
```Python hl_lines="11 18-20" |
|
|
|
{!> ../../docs_src/request_files/tutorial003_an_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ |
|
|
|
|
|
|
|
```Python hl_lines="12 19-21" |
|
|
|
{!> ../../docs_src/request_files/tutorial003_an.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.9+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="9 16" |
|
|
|
{!> ../../docs_src/request_files/tutorial003_py39.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
|
|
|
|
//// tab | Python 3.8+ non-Annotated |
|
|
|
|
|
|
|
/// tip |
|
|
|
|
|
|
|
Prefer to use the `Annotated` version if possible. |
|
|
|
|
|
|
|
/// |
|
|
|
|
|
|
|
```Python hl_lines="11 18" |
|
|
|
{!> ../../docs_src/request_files/tutorial003.py!} |
|
|
|
``` |
|
|
|
|
|
|
|
//// |
|
|
|
{* ../../docs_src/request_files/tutorial003_an_py39.py hl[11,18:20] *} |
|
|
|
|
|
|
|
## Recap |
|
|
|
|
|
|
|