docs/zh-hant/docs/index.md
文件: https://fastapi.tiangolo.com/zh-hant
程式碼: https://github.com/fastapi/fastapi
FastAPI 是一個現代、快速(高效能)的 Web 框架,用於以 Python 並基於標準的 Python 型別提示來構建 API。
主要特點包含:
<small>* 基於內部開發團隊在建立生產應用程式時的測試預估。</small>
{% for sponsor in sponsors.keystone -%} <a href="{{ sponsor.url }}" title="{{ sponsor.title }}"></a> {% endfor -%}
{% for sponsor in sponsors.gold -%} <a href="{{ sponsor.url }}" title="{{ sponsor.title }}"></a> {% endfor -%} {%- for sponsor in sponsors.silver -%} <a href="{{ sponsor.url }}" title="{{ sponsor.title }}"></a> {% endfor %}
<!-- /sponsors -->"[...] 近期大量使用 FastAPI。[...] 我實際上打算在我在微軟團隊的所有機器學習服務上使用它。其中一些正在整合到核心的 Windows 產品,以及一些 Office 產品。"
<div style="text-align: right; margin-right: 10%;">Kabir Khan - <strong>Microsoft</strong> <a href="https://github.com/fastapi/fastapi/pull/26"><small>(ref)</small></a></div>"我們採用了 FastAPI 函式庫來啟動一個 REST 伺服器,供查詢以取得預測。[for Ludwig]"
<div style="text-align: right; margin-right: 10%;">Piero Molino, Yaroslav Dudin, and Sai Sumanth Miryala - <strong>Uber</strong> <a href="https://eng.uber.com/ludwig-v0-2/"><small>(ref)</small></a></div>"Netflix 很高興宣布我們的危機管理協調框架 Dispatch 開源![使用 FastAPI 建構]"
<div style="text-align: right; margin-right: 10%;">Kevin Glisson, Marc Vilanova, Forest Monsen - <strong>Netflix</strong> <a href="https://netflixtechblog.com/introducing-dispatch-da4b8a2a8072"><small>(ref)</small></a></div>"我對 FastAPI 興奮得不得了。超好玩!"
<div style="text-align: right; margin-right: 10%;">Brian Okken - <strong>[Python Bytes](https://pythonbytes.fm/episodes/show/123/time-to-right-the-py-wrongs?time_in_sec=855) podcast 主持人</strong> <a href="https://x.com/brianokken/status/1112220079972728832"><small>(ref)</small></a></div>"老實說,你們做的看起來非常穩健又精緻。很多方面都正是我希望 Hug 成為的樣子——看到有人把它建出來真的很鼓舞人心。"
<div style="text-align: right; margin-right: 10%;">Timothy Crosley - <strong>[Hug](https://github.com/hugapi/hug) 創作者</strong> <a href="https://news.ycombinator.com/item?id=19455465"><small>(ref)</small></a></div>"如果你想學一個用於構建 REST API 的現代框架,看看 FastAPI [...] 它很快、易用、也容易學習 [...]"
"我們的 API 已經改用 FastAPI [...] 我想你會喜歡它 [...]"
<div style="text-align: right; margin-right: 10%;">Ines Montani - Matthew Honnibal - <strong>[Explosion AI](https://explosion.ai) 創辦人 - [spaCy](https://spacy.io) 創作者</strong> <a href="https://x.com/_inesmontani/status/1144173225322143744"><small>(ref)</small></a> - <a href="https://x.com/honnibal/status/1144031421859655680"><small>(ref)</small></a></div>"如果有人想要打造一個可用於生產環境的 Python API,我強力推薦 FastAPI。它設計優雅、簡單易用且高度可擴展,已經成為我們 API first 開發策略中的關鍵元件,推動了許多自動化與服務,例如我們的 Virtual TAC Engineer。"
<div style="text-align: right; margin-right: 10%;">Deon Pillsbury - <strong>Cisco</strong> <a href="https://www.linkedin.com/posts/deonpillsbury_cisco-cx-python-activity-6963242628536487936-trAp/"><small>(ref)</small></a></div>在 2025 年底發布了一支 FastAPI 迷你紀錄片,你可以在線上觀看:
<a href="https://www.youtube.com/watch?v=mpR8ngthqiE"></a>
<a href="https://typer.tiangolo.com"></a>
如果你不是在做 Web API,而是要建立一個在終端機中使用的 <abbr title="Command Line Interface - 命令列介面">CLI</abbr> 應用程式,可以看看 Typer。
Typer 是 FastAPI 的小老弟。他立志成為命令列世界的 FastAPI。⌨️ 🚀
FastAPI 是站在以下巨人的肩膀上:
建立並啟用一個虛擬環境,然後安裝 FastAPI:
<div class="termy">$ pip install "fastapi[standard]"
---> 100%
注意:請務必將 "fastapi[standard]" 用引號包起來,以確保在所有終端機中都能正常運作。
建立檔案 main.py,內容如下:
from fastapi import FastAPI
app = FastAPI()
@app.get("/")
def read_root():
return {"Hello": "World"}
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str | None = None):
return {"item_id": item_id, "q": q}
如果你的程式碼使用 async / await,請使用 async def:
from fastapi import FastAPI
app = FastAPI()
@app.get("/")
async def read_root():
return {"Hello": "World"}
@app.get("/items/{item_id}")
async def read_item(item_id: int, q: str | None = None):
return {"item_id": item_id, "q": q}
注意:
如果你不確定,請查看文件中 "In a hurry?" 章節的關於文件中的 async 與 await。
使用以下指令運行伺服器:
<div class="termy">$ fastapi dev
╭────────── FastAPI CLI - Development mode ───────────╮
│ │
│ Serving at: http://127.0.0.1:8000 │
│ │
│ API docs: http://127.0.0.1:8000/docs │
│ │
│ Running in development mode, for production use: │
│ │
│ fastapi run │
│ │
╰─────────────────────────────────────────────────────╯
INFO: Will watch for changes in these directories: ['/home/user/code/awesomeapp']
INFO: Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
INFO: Started reloader process [2248755] using WatchFiles
INFO: Started server process [2248757]
INFO: Waiting for application startup.
INFO: Application startup complete.
指令 fastapi dev 會讀取你的 main.py,偵測其中的 FastAPI 應用,並使用 Uvicorn 啟動伺服器。
預設情況下,fastapi dev 會在本機開發時啟用自動重新載入。
可在 FastAPI CLI 文件中閱讀更多資訊。
</details>使用瀏覽器開啟 http://127.0.0.1:8000/items/5?q=somequery。
你將會看到以下 JSON 回應:
{"item_id": 5, "q": "somequery"}
你已經建立了一個具有以下功能的 API:
/ 和 /items/{item_id} 接受 HTTP 請求。GET <em>操作</em>(也被稱為 HTTP 方法)。/items/{item_id} 有一個 int 型別的路徑參數 item_id。/items/{item_id} 有一個可選的 str 查詢參數 q。接著前往 http://127.0.0.1:8000/docs。
你會看到自動生成的互動式 API 文件(由 Swagger UI 提供):
現在前往 http://127.0.0.1:8000/redoc。
你會看到另一種自動文件(由 ReDoc 提供):
現在修改 main.py 檔案,使其能從 PUT 請求接收 body。
多虧了 Pydantic,你可以用標準的 Python 型別來宣告 body。
from fastapi import FastAPI
from pydantic import BaseModel
app = FastAPI()
class Item(BaseModel):
name: str
price: float
is_offer: bool | None = None
@app.get("/")
def read_root():
return {"Hello": "World"}
@app.get("/items/{item_id}")
def read_item(item_id: int, q: str | None = None):
return {"item_id": item_id, "q": q}
@app.put("/items/{item_id}")
def update_item(item_id: int, item: Item):
return {"item_name": item.name, "item_id": item_id}
fastapi dev 伺服器應會自動重新載入。
前往 http://127.0.0.1:8000/docs。
現在前往 http://127.0.0.1:8000/redoc。
總結來說,你只需在函式參數中一次宣告參數、body 等的型別。
你使用的是現代標準的 Python 型別。
你不需要學新的語法、特定函式庫的方法或類別,等等。
就用標準的 Python。
例如,對於一個 int:
item_id: int
或是一個更複雜的 Item 模型:
item: Item
…透過一次宣告,你將獲得:
str、int、float、bool、list 等)。datetime 物件。UUID 物件。回到前面的程式碼範例,FastAPI 會:
GET 與 PUT 請求的路徑中是否包含 item_id。GET 與 PUT 請求中的 item_id 是否為 int 型別。
GET 請求中檢查是否有名為 q 的可選查詢參數(如 http://127.0.0.1:8000/items/foo?q=somequery)。
q 參數被宣告為 = None,所以它是可選的。None,則它會是必填(就像 PUT 時的 body)。/items/{item_id} 的 PUT 請求,以 JSON 讀取 body:
name,且為 str。price,且為 float。is_offer,若存在則應為 bool。我們只觸及了表面,但你已經了解它的運作方式了。
試著把這一行:
return {"item_name": item.name, "item_id": item_id}
…從:
... "item_name": item.name ...
…改為:
... "item_price": item.price ...
…然後看看你的編輯器如何自動補全屬性並知道它們的型別:
若想看包含更多功能的完整範例,請參考 <a href="https://fastapi.tiangolo.com/zh-hant/tutorial/">Tutorial - User Guide</a>。
劇透警告:教學 - 使用者指南包含:
maximum_length 或 regex。pytest 的極其簡單的測試你也可以選擇將 FastAPI 應用部署到 FastAPI Cloud,如果你還沒加入,去登記等候名單吧。🚀
如果你已經有 FastAPI Cloud 帳號(我們已從等候名單邀請你 😉),你可以用一個指令部署你的應用。
<div class="termy">$ fastapi deploy
Deploying to FastAPI Cloud...
✅ Deployment successful!
🐔 Ready the chicken! Your app is ready at https://myapp.fastapicloud.dev
就這樣!現在你可以在該 URL 造訪你的應用。✨
FastAPI Cloud 由 FastAPI 的同一位作者與團隊打造。
它讓你以最小的努力精簡地完成 API 的建置、部署與存取流程。
它把用 FastAPI 開發應用的開發者體驗帶到部署到雲端的流程中。🎉
FastAPI Cloud 是「FastAPI 與好朋友們」這些開源專案的主要贊助與資金來源。✨
FastAPI 是開源且基於標準。你可以把 FastAPI 應用部署到任何你選擇的雲端供應商。
依照你雲端供應商的指南來部署 FastAPI 應用吧。🤓
獨立的 TechEmpower 基準測試顯示,在 Uvicorn 下運行的 FastAPI 應用是最快的 Python 框架之一,僅次於 Starlette 與 Uvicorn 本身(FastAPI 內部使用它們)。(*)
想了解更多,請參閱測試結果。
FastAPI 依賴 Pydantic 與 Starlette。
standard 依賴套件 { #standard-dependencies }當你以 pip install "fastapi[standard]" 安裝 FastAPI 時,會包含 standard 這組可選依賴套件:
Pydantic 會使用:
email-validator - 用於電子郵件驗證。Starlette 會使用:
httpx - 若要使用 TestClient 必須安裝。jinja2 - 若要使用預設的模板設定必須安裝。python-multipart - 若要支援表單 <dfn title="將來自 HTTP 請求的字串轉換為 Python 資料">"解析"</dfn>,搭配 request.form()。FastAPI 會使用:
uvicorn - 用於載入並服務你的應用的伺服器。這包含 uvicorn[standard],其中含有一些高效能服務所需的依賴(例如 uvloop)。fastapi-cli[standard] - 提供 fastapi 指令。
fastapi-cloud-cli,可讓你將 FastAPI 應用部署到 FastAPI Cloud。standard 依賴套件 { #without-standard-dependencies }如果你不想包含 standard 可選依賴,可以改用 pip install fastapi(而不是 pip install "fastapi[standard]")。
fastapi-cloud-cli { #without-fastapi-cloud-cli }如果你想安裝帶有 standard 依賴、但不包含 fastapi-cloud-cli,可以使用 pip install "fastapi[standard-no-fastapi-cloud-cli]"。
有些額外依賴你可能也會想安裝。
Pydantic 的額外可選依賴:
pydantic-settings - 設定管理。pydantic-extra-types - 與 Pydantic 一起使用的額外型別。FastAPI 的額外可選依賴:
本專案以 MIT 授權條款釋出。