使用Python实现Rest API指南
在今天的数字化世界中,数据的获取、交换和使用已经成为几乎所有行业的核心部分。无论您正在为一个大型公司设计复杂的软件系统,还是只是为了个人项目尝试获得一些公开的数据,理解和利 用API——尤其是RESTful API——都是一项至关重要的技术。如果你想提升这一项技术,Python是一个非常好的选择,因为它是简单的单易学,而且功能强大。
在接下来的文章中,我们将详细介绍如何使用Python与RESTful API进行交互。我们会从什么是RESTful API开始,然后介绍如何使用Python发送请求、处理响应,并处理可能出现的错误。我们还会介绍一些最实用和有用的库,以帮助您更有效地编写代码。
不管你是初学者还是有经验的开发者,都能在本指南中找到有价值的内容。我们希望这篇文章能帮助你开启或加深对Python与RESTful API交互的理解,从而在你的编程之·上取更大的步骤。让我们现在就开始吧
使用Python实现Rest API指南
- API
- REST架构
- REST API和Web服务
- HTTP方法
- 状态码
- API终点
- REST和Python:使用API
- GET
- POST
- PUT
- PATCH
- DELETE
- REST和Python:构建API
- 识别资源
- 定义你的终点
- 选择你的数据交换格式
- 设计成功响应
- 设计错误响应
- REST和Python:行业工具
- Flask
- Django REST框架
- FastAPI
- 总结
API
API(Application Programming Interface)指的是应用程序编程接口,是一组预定义的方法和规则,用于软件应用程序之间进行交互和通信。API可以让不同的应用程序之间进行数据传输和功能调用,从而实现了应用程序之间的互操作性。
AP通过一些规则和机制,实现一个应用程序或组件与其他应用程序或组件进行交互,API可以以方便的格式返回应用程序所需的数据(例如JSON或XML)

REST架构
REST,全称为表现层状态转移(Representational State Transfer),是一种网络架构风格,被广泛应用于Web服务接口的设计。REST架构中的每一个URL代表一种资源,客户端和服务器之间,传递这种资源的某种表现层。REST通过使用一套统一的接口来实现资源的定义和地址,它利用HTTP协议的方法实现了对这些资源的操作。
以下是REST架构的主要特点:
- 无状态:所有的请求都是独立的,服务器不会存储任何关于客户端请求的信息。每一次请求都需要包含所有必要的信息,这样服务器才能理解并处理请求。这样的设计使得服务器更容易被扩展。
- 客户端-服务器结构:REST应用采用客户端-服务器结构,客户端负责用户交互,服务器负责数据存储和处理,两者通过请求-响应模式进行通信。
- 缓存:服务器的响应可以被客户端缓存起来。这可以提高性能,通过减少一些请求的需要,降低服务器的负载。
- 统一接口:REST通过使用一套统一的接口简化了软件的整个架构。这使得开发人员可以更容易地理解如何使用提供的服务。
- 分层系统:REST允许使用分层系统架构,每一层只知道与自己直接交互的那一层。这样的设计使得组件可以独立开发,而不影响系统的其他部分。
- 按需代码:服务器可以选择性地将可执行代码或者脚本提供给客户端,在客户端环境中执行。这使得客户端可以更灵活地适应不同的需要。
REST架构风格的设计使得Web服务更易于扩展、修改和理解,使得它成为了现代Web服务设计的首选方式。在接下来的部分,我们将会详细介绍如何使用Python来创建和使用REST API。
注意REST不是标准或协议,这是编写API的方法或架构风格。
可以将REST API比作一个翻译官可能是一个合适的类比。
想象你是一个中国人,你想和一个只会说英语的美国人进行交流,但是你不会英语,所以你需要一个翻译官帮你。在这个情况下,翻译官就扮演了REST API的角色。
你告诉翻译官你的需求,也就是你要表达的内容(Request),然后翻译官会将这个信息翻译成英语并告诉那个美国人。之后,美国人给出的回应也会被翻译官转译成中文再告诉你(Response)。这个过程就相当于你(一个客户端)通过REST API向一个服务进行请求,并得到响应。
REST API以HTTP方法(如GET、POST、PUT、DELETE)作为动作,让你的请求更明确。就像是你告诉翻译官你要做什么——你要询问一个问题(GET),你要分享一些新消息(POST),你要更改之前说过的某件事(PUT),或者你要撤回之前说过的话(DELETE)。
数据在此过程中是如何传递的呢?翻译官并不会让你直接与美国人对话,而是通过一种标准的语言(比如JSON或XML)来传递信息。这就像是REST API使用特定格式的数据(通常是JSON)来确保信息正确无误地在你和服务之间传递。
就这样,REST API,就像一个翻译官,通过特定的动作和标准的语言,将你的需求清晰准确地传达给了服务,同时也将服务的回应翻译给你,使你能够与只说“英语”的服务进行有效的交流。
REST API和Web服务
REST(表示性状态转移)API是一种使用HTTP协议为Web服务提供接口的架构风格。它提供了一种简单有效的方法,允许不同软件应用通过HTTP协议进行通信和交互数据。Python由于其易读性和高效性,常被用来创建和使用REST API
HTTP方法
在REST API中,HTTP方法是定义客户端可能对服务器资源进行何种操作的方式。以下是最常见的HTTP方法:
- GET:用于获取资源。
- POST:用于创建新的资源。
- PUT:用于更新现有资源。它通常需要客户端提供完整的资源数据。
- PATCH:也用于更新现有资源,但通常只需要客户端提供部分需要更改的数据。
- DELETE:用于删除资源。这些方法对应了CRUD(创建、读取、更新、删除)操作,是构建Web服务的基本操作。
状态码
HTTP状态码是服务器在响应客户端请求时返回的一个三位数。这些代码为我们提供了请求的处理情况。以下是一些常见的HTTP状态码:
- 200 OK:请求成功,一切正常。
- 201 Created:POST请求成功,并且服务器创建了新的资源。
- 204 No Content:服务器成功处理了请求,但没有返回任何内容。
- 400 Bad Request:服务器不能理解客户端的请求。
- 401 Unauthorized:客户端尝试访问需要身份验证的资源。
- 403 Forbidden:客户端没有权限访问该资源。
- 404 Not Found:服务器找不到请求的资源。
- 500 Internal Server Error:服务器遇到了错误,无法完成请求
API终点
在REST API中,终点(Endpoint)是用于定义API如何访问资源的URL。每个终点都与一个HTTP方法配对,表示对特定资源的操作。例如,GET /users 可能用于获取所有用户的信息,而 POST /users 可能用于创建新的用户。
终点应该是清晰的,能够清楚地表明它代表的资源。例如,/users/123 代表了 ID 为 123 的用户。
总的来说,了解HTTP方法、状态码和API终点是使用和创建REST API的基础。在下一部分,我们将介绍如何在Python中使用这些知识来消费和创建REST API。
REST和Python:使用API
Python是构建和使用REST API的理想选择,因为它拥有众多的库和框架,可以让你更加便捷地处理HTTP请求。在这个部分,我们将通过Python的requests库,详细介绍如何使用GET, POST, PUT, PATCH和DELETE方法。
GET
GET是最常用的HTTP方法,用于从服务器检索信息。在Python中,我们可以使用requests库的get方法来实现。下面是一个例子:
import requestsresponse = requests.get('https://api.example.com/items')
这行代码会向https://api.example.com/items发送一个GET请求。你可以通过response.content来获取响应的内容。
POST
POST方法常用于向服务器发送数据,创建新的资源。在requests库中,可以使用post方法,并通过data参数传递数据:
import requestsdata = {'key1': 'value1', 'key2': 'value2'}
response = requests.post('https://api.example.com/items', data=data)
这段代码会向服务器发送一个POST请求,并传递一个字典作为数据。
PUT
PUT方法用于更新现有资源。它与POST方法类似,也使用data参数来传递要更新的数据:
import requestsdata = {'key1': 'new_value1', 'key2': 'new_value2'}
response = requests.put('https://api.example.com/items/1', data=data)
这段代码会更新ID为1的item的数据。
PATCH
PATCH方法也用于更新资源,但它通常只更新资源的一部分,而不是全部内容。在requests库中,也是使用data参数来传递数据:
import requestsdata = {'key1': 'new_value1'}
response = requests.patch('https://api.example.com/items/1', data=data)
上述代码将只更新ID为1的item的key1字段
DELETE
DELETE方法用于删除服务器上的资源。在requests库中,可以这样使用:
import requestsresponse = requests.delete('https://api.example.com/items/1')
这行代码将会删除ID为1的item。以上就是如何在Python中使用REST API的基本操作。在下一部分,我们将探讨如何在Python中创建自己的REST API。
REST和Python:构建API
构建REST API不仅仅是编写代码,更需要良好的设计和规划。以下是一些你需要考虑的关键步骤。
识别资源
在REST API中,"资源"是你想要通过API暴露的数据。资源可以是任何东西,例如用户、订单、图片等。你需要识别出应用中所有重要的资源,并确定你需要通过API提供哪些操作。每个资源通常都会有其自己的URI,可以通过不同的HTTP方法对其进行操作
定义你的终点
一旦你识别出所有的资源,下一步就是为它们定义终点。终点就是资源的URL,通常表现为复数形式的名词,如/users,/orders等。每个资源都应该至少有一个终点,并与一个或多个HTTP方法相关联。
选择你的数据交换格式
数据交换格式是客户端和服务器交换数据的方式。最常见的格式是JSON和XML,但JSON由于其简单性和易读性,成为了更受欢迎的选择。Python有内建的json模块,可以帮助你轻松地编码和解码JSON数据
设计成功响应
当请求成功时,你的API应该返回一个合适的HTTP状态码(通常是200或201),以及一些信息。这些信息通常包括被创建或修改的资源,或者是一些有用的元数据。例如:
{"status": "success","data": {"id": 1,"name": "John"}
}
设计错误响应
当请求失败时,你的API应该返回一个错误状态码(如400,401,404等),以及一个错误消息,解释为什么请求失败。例如:
{"status": "error","message": "Invalid credentials"
}
构建REST API需要深思熟虑和周全的设计,但Python提供了许多工具和库,如Flask和Django,使得这个过程更加简单。在下一部分,我们将介绍这些工具和如何使用它们来创建你的REST API。
REST和Python:行业工具
Python社区为开发REST API提供了许多工具。在这个部分,我们将详细介绍最常见的三个工具:Flask,Django REST框架,和FastAPI。
Flask
Flask是一个轻量级的Web框架,它的主要优点是简单易用。你可以使用Flask轻松地构建REST API。以下是一个基本的示例:
from flask import Flask, jsonifyapp = Flask(__name__)@app.route('/api/items', methods=['GET'])
def get_items():items = [{"id": 1, "name": "Item 1"}, {"id": 2, "name": "Item 2"}] # 获取资源的代码return jsonify(items)if __name__ == '__main__':app.run(debug=True)
在这个示例中,我们定义了一个API终点/api/items,该终点对GET请求做出响应,返回一个包含两个项目的列表
Django REST框架
Django REST框架是一个强大的Web框架,它提供了许多工具和功能,使得创建复杂的REST API变得简单。以下是一个基本的示例
from django.urls import path
from rest_framework.response import Response
from rest_framework.decorators import api_view@api_view(['GET'])
def get_items(request):items = [{"id": 1, "name": "Item 1"}, {"id": 2, "name": "Item 2"}]return Response(items)urlpatterns = [path('api/items', get_items),
]
在这个示例中,我们使用Django REST框架定义了一个API终点。当用户向/api/items发送GET请求时,服务器将返回一个包含两个项目的列表
FastAPI
FastAPI是一个现代、快速(高性能)的Web框架,用于构建API。其主要优点包括快速编码、减少bug、直观、易用、设计简单直观、适合用于构建微服务等。以下是一个基本的示例:
from fastapi import FastAPI
from pydantic import BaseModel
from typing import Listapp = FastAPI()class Item(BaseModel):id: intname: stritems = [Item(id=1, name="Item 1"), Item(id=2, name="Item 2")]@app.get('/api/items', response_model=List[Item])
def get_items():return items
这个示例中,我们使用FastAPI和Pydantic定义了一个API终点。当用户向/api/items发送GET请求时,服务器将返回一个包含两个项目的列表。以上就是Python中最常见的三个构建REST API的工具。它们都有各自的优缺点,你可以根据项目的具体需求来选择使用哪一个。
总结
在Python中使用和构建REST API是一个非常重要的技能。通过这篇文章,我们已经了解了REST API的基本概念,以及如何在Python中进行操作。我们还了解了Flask、Django REST框架和FastAPI这三个最常用的工具,它们可以帮助我们更加高效地构建REST API。
在构建REST API时,以下是一些重要的技巧和最佳实践:
- 始终使用HTTP方法:在设计API时,始终使用正确的HTTP方法。例如,使用GET来获取数据,POST来创建数据,PUT和PATCH来更新数据,DELETE来删除数据。
- 使用合适的状态码:当API响应请求时,始终返回正确的HTTP状态码。这对于调用API的客户端来说是非常有用的。
- 保持终点的一致性:尽量保持API终点的一致性。如果一个终点用于获取资源,那么其他类似的终点也应该用于获取资源。
- 错误处理:当API发生错误时,应该返回一个明确的错误消息,以帮助客户端理解问题所在。
- 使用易于理解的资源命名:资源应该使用易于理解的名词,避免使用技术术语。
- 版本控制:如果API可能会发生更改,考虑使用版本控制。这可以通过在URL或请求头中包含版本号来实现。通过遵循这些最佳实践,你可以构建出高效、易用和可维护的REST API。总的来说,构建REST API需要深思熟虑和周全的设计,但Python提供了许多工具和库,使得这个过程更加简单。
相关文章:
使用Python实现Rest API指南
在今天的数字化世界中,数据的获取、交换和使用已经成为几乎所有行业的核心部分。无论您正在为一个大型公司设计复杂的软件系统,还是只是为了个人项目尝试获得一些公开的数据,理解和利 用API——尤其是RESTful API——都是一项至关重要的技术。…...
【2023 · CANN训练营第一季】进阶班 应用开发深入讲解→模型推理
1 模型离线推理 各步要解析如下: Host&Device内存管理与数据传输: Host&Device上的内存申请与释放,内存间的相互拷贝;模型加载:将离线的om文件加载到Device上;在样例的资源初始化模块中进行。模型输入输出准备∶根据禹线om的输入输出,在Device…...
单词分析问题
题目描述 小蓝正在学习一门神奇的语言,这门语言中的单词都是由小写英文字母组 成,有些单词很长,远远超过正常英文单词的长度。小蓝学了很长时间也记不住一些单词,他准备不再完全记忆这些单词,而是根据单词中哪个字母出…...
3个月出国|材料科学老师自费赴韩国访学
K老师指定韩国为访学的目标国家,希望专业匹配,尽快出国。最终我们获得了韩国庆北大学的邀请函,其学校名气、专业匹配度及导师影响力都符合K老师的要求。本案例从开始委托我们申请到最终出国,仅仅用时3个月。 K老师背景:…...
MaaS来临,SaaS进入「奇点」时刻|产业深度
大模型热度持续发酵。MaaS的到来,不仅改变了云厂商的竞争格局,SaaS行业也将迎来「奇点」时刻。未来十年,基于MaaS底座,国内SaaS甚至可能会出现Salesforce一样的巨头。 作者|思杭 编辑|皮爷 出品|产业家 大模型热度正在持续发酵。…...
课程分享:华清远见联合NXP推出i.MX8M Plus开发与实践课程,超干超实用!
课程名称: i.MX8M Plus开发与实践课程 课程介绍: i.MX8M Plus应用处理器是NXP推出的一款致力于推动机器学习(ML),机器视觉,多媒体与工业边缘物联网应用的工业人工智能芯片。拥有4个ARM Cortex-A53核心…...
idea将java程序打包为jar
idea将java程序打包为jar 灵光一现: 用java拉起浏览器,打开指定的网络地址,省的手动打开浏览器再复制地址过去了 本文记录了使用idea将java程序打包为jar包的过程 源码地址:https://gitcode.net/qq_39339588/jar.git 文章目录 ide…...
快速掌握Redis基础知识及使用技巧
Redis 是一个高性能、基于内存的键值数据库,其主要特点是支持多种数据结构和高并发读写操作。在本文中,我们将介绍 Redis 的基本概念和使用方法,以帮助读者快速入门 Redis。 Redis 的基本概念 Redis 是一种基于内存的高性能 key-value 存储系…...
C++控制台打飞机小游戏
我终于决定还是把这个放出来。 视频在这:https://v.youku.com/v_show/id_XNDQxMTQwNDA3Mg.html 具体信息主界面上都有写。 按空格暂停,建议暂停后再升级属性。 记录最高分的文件进行了加密。 有boss(上面视频2分47秒)。 挺好…...
Pinna的使用以及pinna的持续化存储(两种方法)
一、简介 pinia是 vue3 新的状态管理工具,简单来说相当于之前 vuex,它去掉了 Mutations 但是也是支持 vue2 的,需要的朋友可以参考下 二、使用方法 1.安装 npm install pinia -S 2..引入 import { createPinia,PiniaPluginContext } from p…...
开发中造成空指针的常见用法,如何避免
1. 前言 《手册》的第 7 页和 25 页有两段关于空指针的描述: 【强制】Object 的 equals 方法容易抛空指针异常,应使用常量或确定有值的对象来调用 equals。 【推荐】防止 NPE,是程序员的基本修养,注意 NPE 产生的场景: 返回类型为…...
MySQL事务和索引
目录 事务的概念 事务的四大特性(ACID) 原子性 隔离性 持久性 一致性 什么是脏读、幻读和不可重复读? 脏读 幻读 不可重复读 事务的隔离级别 读未提交 读已提交 可重复读 串行化 索引 索引优点 索引缺点 索引分类 索引设…...
Kali工具集简介
Kali Linux提供了数种经过定制的专门为渗透测试设计的工具。工具都会按下图中下拉选单所示的方式按组分类聚合。了解工具是做渗透测试第一个认知。 口Information Gathering(信息收集) 这些都是侦察工具,用来收集目标网络和设备的数据。在这类工具中,从找出设备的工具到查看使…...
离散数学 | 图论 | 欧拉图 | 哈密顿图 | 割点 | 桥(欧拉图和哈密顿图有没有割点和桥?)
本文主要解决以下几个问题: 1.欧拉图能不能有割点,能不能有桥? 2.哈密顿图能不能有割点,能不能有桥? 首先我们要明白几个定义 割点的定义就是在一个图G中,它本来是连通的,去掉一个点v以后这个…...
Android生命周期:理解与应用
摘要:Android生命周期是开发Android应用程序时至关重要的概念。本文将介绍Android生命周期的概念、生命周期方法的执行顺序以及如何在应用程序中正确地管理生命周期。我们还将讨论生命周期对于应用程序的重要性,并提供一些实际应用中的最佳实践和注意事项…...
00后真的是内卷王中王,真的想离职了....
都说00后躺平了,但是有一说一,该卷的还是卷。这不,前段时间我们公司来了个00年的,工作没两年,跳槽到我们公司起薪18K,都快接近我了。后来才知道人家是个卷王,从早干到晚就差搬张床到工位睡觉了。…...
linux Fd以及重定向讲解
感谢你的阅读,是对我最大的鼓励!!!! 目录 fd理解 文件操作重定向 让我们回顾C语言文件操作 首选我们要知道2个知识点: 额外知识点 如何理解一切皆文件呢? 当父进程fork创建子进程是否创建…...
Moonbeam近日提案公投一览
正在跟进Moonbeam治理的小伙伴,一起来快速浏览一下近期生态中正在发生的事情吧!其中包含多个去中心化应用的Grant加速计划提案、HRMP开拓提案以及优化质押相关平台的内容。许多提案都与网络的运作息息相关,一起了解和参与Moonbeam的发展吧&am…...
凝聚青年力量,打造数字化人才队伍
当代青年人勇于探索、敢于创新、勤于变革,积极承担社会责任。这与ABeam倡导的「Build Beyond As One.™」的品牌理念不谋而合。ABeam的青年员工是未来社会的中坚力量,也正用他们的青春能量助力ABeam在中国的发展。 01 新兴青年力量 对ABeam而言&#…...
蓝牙资讯|智能家居标准Matter 1.1 发布,智能家居产品兼容更丰富
据“CSA 连接标准联盟”官方微信号,Matter 1.1 版本已发布,“1.1 版本带来的更新使设备制造商和开发者上手更容易、产品获取认证更方便,也让产品能更快地交付给用户。该版本还为电池供电设备提供了更大支持,而这类设备涉及多种类型…...
[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解
突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 安全措施依赖问题 GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...
UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...
1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
屋顶变身“发电站” ,中天合创屋面分布式光伏发电项目顺利并网!
5月28日,中天合创屋面分布式光伏发电项目顺利并网发电,该项目位于内蒙古自治区鄂尔多斯市乌审旗,项目利用中天合创聚乙烯、聚丙烯仓库屋面作为场地建设光伏电站,总装机容量为9.96MWp。 项目投运后,每年可节约标煤3670…...
微信小程序云开发平台MySQL的连接方式
注:微信小程序云开发平台指的是腾讯云开发 先给结论:微信小程序云开发平台的MySQL,无法通过获取数据库连接信息的方式进行连接,连接只能通过云开发的SDK连接,具体要参考官方文档: 为什么? 因为…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
如何在网页里填写 PDF 表格?
有时候,你可能希望用户能在你的网站上填写 PDF 表单。然而,这件事并不简单,因为 PDF 并不是一种原生的网页格式。虽然浏览器可以显示 PDF 文件,但原生并不支持编辑或填写它们。更糟的是,如果你想收集表单数据ÿ…...
蓝桥杯 冶炼金属
原题目链接 🔧 冶炼金属转换率推测题解 📜 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V,是一个正整数,表示每 V V V 个普通金属 O O O 可以冶炼出 …...
管理学院权限管理系统开发总结
文章目录 🎓 管理学院权限管理系统开发总结 - 现代化Web应用实践之路📝 项目概述🏗️ 技术架构设计后端技术栈前端技术栈 💡 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 🗄️ 数据库设…...
