Browse Source

📝 Update includes in `docs/en/docs/tutorial/request-files.md` (#12818)

pull/12821/head
Zhaohan Dong 5 months ago
committed by GitHub
parent
commit
170826c911
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 260
      docs/en/docs/tutorial/request-files.md

260
docs/en/docs/tutorial/request-files.md

@ -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

Loading…
Cancel
Save