【超详细】Python FastAPI 入门:写给新手的“保姆级”教程

【超详细】Python FastAPI 入门:写给新手的“保姆级”教程(2025–2026 最新版)

这篇教程的目标是:
零基础 → 能独立写出生产级别的 RESTful API
预计认真跟着做完前 80%,你大概需要 3–10 天(每天 2–4 小时)。

目录(建议按顺序阅读)

  1. 为什么选择 FastAPI(而不是 Flask / Django)
  2. 环境准备(最稳的几种方式)
  3. 第一个 FastAPI 程序(Hello World)
  4. 核心概念速览(5 分钟建立大局观)
  5. 路径参数、查询参数、请求体(最常用三大输入方式)
  6. 响应模型 & 状态码
  7. 依赖注入(Dependency Injection)入门
  8. 异步 vs 同步(什么时候用 async def)
  9. 数据库连接(SQLAlchemy + asyncpg 推荐组合)
  10. 自动生成的交互式文档(Swagger & ReDoc)
  11. 错误处理 & 自定义异常
  12. 安全基础(JWT + OAuth2)
  13. 项目结构推荐(中大型项目怎么组织)
  14. 部署(Docker + gunicorn + uvicorn 最常见组合)
  15. 常见问题 & 调试技巧

1. 为什么选择 FastAPI(2025–2026 视角)

维度FastAPIFlaskDjango结论(2025–2026)
开发速度★★★★★★★★★☆★★★☆☆最快
性能接近 Node.js / Go中等中等偏下目前 Python 最快
自动文档OpenAPI + Swagger + ReDoc需手动或扩展admin 强大但 API 需额外写碾压
类型提示支持原生 Pydantic v2需插件部分支持现代开发标配
异步支持原生 async/await需 gevent 或异步扩展Channels(较重)天生异步
学习曲线(新手)中等(但文档极好)最低较高性价比最高
社区活跃度爆炸式增长成熟但增速放缓非常成熟未来 3–5 年首选

一句话结论:
如果你 2025–2026 年想用 Python 写高性能、现代、好维护的 API,FastAPI 几乎是唯一主流选择。

2. 环境准备(选一种最适合你的)

推荐组合(最稳)
Python 3.10 / 3.11 / 3.12 + uv / pdm / poetry(现代包管理) + venv

最快上手方式(5 分钟)

# 方式一:用 uv(2025 年最推荐的极简工具,速度比 pip 快 10–100 倍)curl -LsSf https://astral.sh/uv/install.sh |sh uv venv source .venv/bin/activate # Windows 用 .venv\Scripts\activate uv pip install fastapi[standard] uvicorn[standard]

备选方式(经典 pip + venv)

python -m venv venv source venv/bin/activate # Windows: venv\Scripts\activate pip install --upgrade pip pip install fastapi[standard] uvicorn[standard]

安装完成后运行下面代码测试:

# main.pyfrom fastapi import FastAPI app = FastAPI()@app.get("/")defread_root():return{"Hello":"FastAPI"}

启动:

uvicorn main:app --reload # 或 python -m uvicorn main:app --reload 

浏览器打开:http://127.0.0.1:8000
看到 JSON 就成功了!

再访问 http://127.0.0.1:8000/docs → 自动 Swagger 界面出现,恭喜你进入 FastAPI 世界!

3. 核心概念速览(5 分钟建立心智模型)

概念通俗解释代码例子简写
FastAPI()创建应用实例app = FastAPI()
@app.get/post/…路由装饰器@app.get(“/items/{item_id}”)
路径参数URL 里的动态部分item_id: int
查询参数?key=valueq: str = None
请求体POST/PUT 里的 JSONitem: Item
Pydantic BaseModel数据验证 + 序列化 + 自动文档class Item(BaseModel): …
Depends依赖注入(认证、数据库、配置等)Depends(get_current_user)
BackgroundTasks后台任务(发邮件、记录日志)background_tasks.add_task(…)

4. 经典入门案例:图书管理 API(边学边写)

我们用一个“简易图书管理系统”贯穿全文。

models.py

from pydantic import BaseModel, Field from typing import Optional classBookBase(BaseModel): title:str= Field(..., min_length=1, max_length=100) author:str= Field(..., min_length=1, max_length=50) year:int= Field(..., ge=1900, le=2100)classBookCreate(BookBase):passclassBook(BookBase):id:int is_available:bool=TrueclassConfig: from_attributes =True# 兼容 ORM

main.py(逐步添加)

from fastapi import FastAPI, HTTPException, Query, Path from typing import List from models import Book, BookCreate app = FastAPI(title="图书管理 API", version="0.1.0")# 假数据库 books_db: List[Book]=[ Book(id=1, title="Python速成", author="重阳", year=2025),]@app.get("/books/", response_model=List[Book])defget_books( skip:int= Query(0, ge=0), limit:int= Query(10, ge=1, le=100), author: Optional[str]=None): result = books_db[skip : skip + limit]if author: result =[b for b in result if b.author.lower()== author.lower()]return result @app.get("/books/{book_id}", response_model=Book)defget_book(book_id:int= Path(..., ge=1)):for book in books_db:if book.id== book_id:return book raise HTTPException(status_code=404, detail="图书不存在")@app.post("/books/", response_model=Book, status_code=201)defcreate_book(book: BookCreate): new_id =max(b.idfor b in books_db)+1if books_db else1 new_book = Book(id=new_id,**book.model_dump()) books_db.append(new_book)return new_book 

启动后就能在 Swagger 上直接测试增删改查了。

下一阶段预告(建议按顺序继续)

  • 第 5–8 节:请求体、响应模型、依赖注入、异步路由
  • 第 9–10 节:连真实数据库(PostgreSQL + SQLAlchemy 异步)
  • 第 11–13 节:认证(JWT)、项目结构、错误处理
  • 第 14–15 节:Docker 部署 + 生产化配置

你现在最想先深入哪一部分?

  1. 继续跟着上面的图书系统写数据库部分(SQLAlchemy async)
  2. 先把认证(JWT + OAuth2)补上
  3. 想看完整项目结构推荐(文件夹怎么分)
  4. 想直接看 Docker + 生产部署方案
  5. 有具体报错或想改某个功能(告诉我)

回复我,我继续陪你写下去~ 😄

Read more

MySQL 登录报错 ERROR 1045:Access denied for user ‘root‘@‘localhost‘(using password: YES

目录 1. 问题描述 2. 错误原因解析 3. 多种解决方案 * 方案一:重设 root 密码 * 方案二:检查并修正用户权限 * 方案三:修改配置文件启动选项 4. 总结 5. 附加建议 1. 问题描述 在使用 MySQL 时,经常会遇到以下报错: ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) 即 root 用户从 localhost 登陆时被拒绝访问。本文将分析该问题的可能原因,并给出几种常用解决方案。 2. 错误原因解析

By Ne0inhk
《MySQL 表基础语法:从入门到熟练的核心技巧》

《MySQL 表基础语法:从入门到熟练的核心技巧》

前引:MySQL 表的增删查是数据库操作的基础,也是日常开发、数据分析中最高频的需求。很多初学者会卡在语法细节、场景适配或效率优化上,明明掌握了基础命令,实际应用中却频频出错。本文聚焦 “实用 + 避坑”,从核心语法到高频场景,再到优化技巧,帮你彻底吃透 MySQL 表增删查,告别 “只会用不会用对” 的尴尬 SQL查询中各个关键字的执行先后顺序: from > on> join > where > group by > with > having > select > distinct > order by > limit 目录 【一】增 (1)基本创建 (2)

By Ne0inhk
【比亚迪璇玑架构深度解析:重新定义智能电动汽车的“整车智能”】

【比亚迪璇玑架构深度解析:重新定义智能电动汽车的“整车智能”】

比亚迪璇玑架构深度解析:重新定义智能电动汽车的“整车智能” 揭秘行业首个智电融合智能化架构,如何实现从感知到执行的全面协同 📖 目录 1. #1-前言 2. #2-关键词 3. #3-一璇玑架构核心组成一脑两端三网四链 4. #4-二璇玑架构的底层原理与技术实现 5. #5-三璇玑架构的行业优势与影响 6. #6-四应用实例天神之眼c-dipilot-100 7. #7-五代码示例能量管理策略伪代码 8. #8-六总结与展望 9. #9-参考资料与链接 10. #10-附录璇玑架构核心思想导图 1. 前言 随着汽车产业进入智能化“下半场”,各大车企纷纷推出自己的智能化解决方案。比亚迪作为全球新能源汽车的领导者,在2024年初发布了行业首个智电融合的智能化架构——璇玑架构。这不仅是比亚迪技术实力的集中体现,更是其对“整车智能”理念的深度实践。 璇玑架构打破了传统“智舱”和“智驾”的分离式开发模式,实现了从电动化底层到智能化顶层的全面融合。本文将从工程师视角,深度解析璇玑架构的技术原理、创新点和行业影响。 2. 关键词 璇玑架构

By Ne0inhk
OpenClaw Gateway 安装失败:systemctl --user is-enabled unavailable 排查与解决(完整踩坑记录)

OpenClaw Gateway 安装失败:systemctl --user is-enabled unavailable 排查与解决(完整踩坑记录)

说明:仅供学习使用,请勿用于非法用途,若有侵权,请联系博主删除 作者:zhu6201976 最近在安装 OpenClaw Gateway 时,遇到了一个比较奇怪的错误: systemctl is-enabled unavailable Command failed: systemctl --user is-enabled openclaw-gateway.service 看起来只是一个简单的 systemd 错误,但实际上背后涉及: * systemd user service * Node.js / nvm 环境 * PATH 环境变量 * CLI daemon 启动方式 这篇文章记录了 完整的排查过程 + 最终解决方案。 一、运行环境 我的环境如下: Window11 + WSL2 Ubuntu 24.04.4

By Ne0inhk