Python高性能web框架-FastApi教程:(1)创建一个简单的FastApi

(1)创建一个简单的FastApi

1. 导入必要的库
python 复制代码
from fastapi import FastAPI
import uvicorn
  • FastAPI 是一个用于构建现代、快速(高性能)的Web API的Python框架。
  • uvicorn 是一个ASGI服务器,用于运行异步的Python Web应用程序。
2. 创建FastAPI实例
python 复制代码
app = FastAPI()
  • 这行代码创建了一个FastAPI应用实例,这个实例将用于定义和处理路由。
3. 定义路由
python 复制代码
@app.get('/')
async def home():
    return {'user_id': 1002}
  • @app.get('/') 是一个装饰器,用于定义一个GET请求的路由,路径为根目录/
  • async def home(): 定义了一个异步函数home,当接收到根目录/的GET请求时,这个函数将被调用。
  • return {'user_id': 1002} 返回一个包含用户ID的字典。
python 复制代码
@app.get('/shop')
async def shop():
    return {'shop': '商品信息'}
  • @app.get('/shop') 是一个装饰器,用于定义一个GET请求的路由,路径为/shop
  • async def shop(): 定义了一个异步函数shop,当接收到/shop的GET请求时,这个函数将被调用。
  • return {'shop': '商品信息'} 返回一个包含店铺信息的字典。
4. 运行FastAPI应用
python 复制代码
if __name__ == '__main__':
    uvicorn.run('main:app', port=8080, reload=True)
  • if __name__ == '__main__': 检查是否直接运行此脚本。
  • uvicorn.run('01_quickstart:app', port=8080, reload=True) 使用uvicorn运行FastAPI应用,指定端口为8080,并启用自动重新加载功能。这样在开发过程中,代码修改后会自动重启服务器。

通过以上步骤,你可以创建一个简单的FastAPI应用,并定义两个GET请求的路由来返回不同的数据。

5.完成代码如下
python 复制代码
from fastapi import FastAPI
import uvicorn

app = FastAPI()

@app.get('/')
async def home():
    return {'user_id': 1002}

@app.get('/shop')
async def shop():
    return {'shop': '商品信息'} 

if __name__ == '__main__': 
    uvicorn.run('main:app', port=8080, reload=True)
6.测试

FastAPI自带swagger接口调试文档,因此这里可以直接打开swagger页面 127.0.0.1:8080/docs,然后即可调试了,如下:

swagger测试录屏

相关推荐
寻月隐君4 分钟前
Python 数据结构与算法:课程笔记与实战解析
后端·python·github
红队it20 分钟前
【数据分析大屏】基于Django+Vue汽车销售数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅
python·数据分析·spark·汽车·大屏端
蹦蹦跳跳真可爱58928 分钟前
Python----计算机视觉处理(opencv:图片灰度化)
人工智能·python·opencv·计算机视觉
HelloGitHub1 小时前
经过 10 亿级性能验证的隐私计算开源利器
python·开源·github
一号言安1 小时前
牛客python蓝桥杯11-32(自用)
开发语言·python
梦丶晓羽2 小时前
自然语言处理:主题模型
人工智能·python·自然语言处理·lda·主题模型
weixin_525936332 小时前
Python数据分析之机器学习基础
python·机器学习·数据分析
apcipot_rain2 小时前
【密码学——基础理论与应用】李子臣编著 第三章 分组密码 课后习题
python·算法·密码学
慕丹2 小时前
项目工坊 | Python驱动淘宝信息爬虫
爬虫·python·selenium
萌小丹Fighting6 小时前
【Python爬虫】使用python脚本拉取网页指定小说章节
爬虫·python