2.5 python接口编程

在现代软件开发的复杂生态系统中,不同系统、模块之间的交互协作至关重要。接口编程作为一种关键机制,定义了组件之间的通信规范与交互方式。Python 凭借其卓越的灵活性、丰富的库资源以及简洁易读的语法,在接口编程领域占据了重要地位,广泛应用于各类项目开发中,从 Web 应用到数据处理,再到自动化测试等场景。​

一、接口编程基础概念​

(一)接口的定义​

从本质上讲,接口是一种抽象的规范,它规定了一组方法或行为的签名,但不涉及这些方法的具体实现。在 Python 中,虽然没有像 Java 或 C++ 那样严格意义上的接口关键字,但可以通过抽象基类(ABC)以及抽象方法来模拟接口的概念。例如,使用abc模块创建一个抽象基类,其中的抽象方法强制子类必须实现特定行为,从而确保不同类在遵循相同接口规范下进行交互。​

(二)接口编程的作用​

接口编程最大的优势在于解耦。通过定义清晰的接口,不同模块或系统之间可以独立开发、测试和维护。当一个模块需要与其他模块交互时,只需关注接口所定义的输入输出和行为,而无需了解其内部实现细节。这不仅提高了代码的可维护性,也增强了系统的扩展性。例如,在一个电商系统中,订单处理模块与支付模块通过接口进行交互,支付模块可以随时替换为不同的支付提供商实现,只要它遵循订单处理模块所期望的接口规范,整个系统的其他部分无需进行大规模改动。​

二、Python 接口编程的优势​

(一)动态语言特性​

Python 作为动态语言,在接口编程中展现出极大的灵活性。它允许在运行时动态地绑定方法和属性,这意味着可以在程序运行过程中根据实际需求来调整接口的行为。相比静态语言,Python 无需在编译阶段就确定接口的具体实现,降低了开发的复杂性,提高了开发效率。例如,在编写一个数据处理接口时,可以根据输入数据的类型在运行时动态选择不同的处理函数,而不需要事先定义大量的静态类型检查。​

(二)丰富的库支持​

Python 拥有庞大的标准库和第三方库生态系统,这为接口编程提供了有力支持。例如,Flask和Django等 Web 框架用于构建 Web 接口,它们提供了便捷的路由系统、请求处理机制以及与数据库的交互接口,使得开发 RESTful API 变得轻而易举。FastAPI则专注于高性能的 API 开发,利用 Python 的类型提示功能,在保证代码可读性的同时,能自动生成 API 文档。在数据交换方面,requests库用于发送 HTTP 请求,方便地与其他系统的接口进行通信;pandas库可以高效处理结构化数据,常用于接口数据的解析和转换。​

三、Python 接口编程的实现方式

(一)Web 接口开发

1. 基于 Flask 框架​

Flask 是一个轻量级的 Web 框架,非常适合快速搭建小型 Web 接口。在创建接口时,首先需要安装 Flask 库,通过pip install flask即可完成安装。接着,导入Flask类并创建应用实例。例如,定义一个简单的获取用户信息的接口:

from flask import Flask, jsonifyapp = Flask(__name__)@app.route('/api/user/<int:user_id>', methods=['GET'])
def get_user(user_id):# 这里模拟从数据库获取用户信息user = {'id': user_id, 'name': 'John Doe', 'email': 'johndoe@example.com'}return jsonify(user)if __name__ == '__main__':app.run(debug=True)

在上述代码中,@app.route装饰器用于定义接口的 URL 路径,<int:user_id>是动态参数,methods=['GET']指定该接口仅接受 GET 请求。jsonify函数将 Python 字典转换为 JSON 格式的数据返回给客户端。

2. 基于 Django 框架​

Django 是一个功能强大、全栈式的 Web 框架,适用于开发大型复杂的 Web 接口。创建 Django 项目后,在views.py文件中定义视图函数来处理接口请求。例如,创建一个处理用户注册的接口:

from django.http import JsonResponse
from django.views.decorators.csrf import csrf_exempt
import json@csrf_exempt
def register_user(request):if request.method == 'POST':try:data = json.loads(request.body)username = data.get('username')password = data.get('password')# 这里进行用户注册逻辑,如保存到数据库return JsonResponse({'status':'success','message': 'User registered successfully'})except json.JSONDecodeError:return JsonResponse({'status': 'error','message': 'Invalid JSON data'}, status = 400)else:return JsonResponse({'status': 'error','message': 'Only POST method is allowed'}, status = 405)

3. 基于 FastAPI 框架

FastAPI 基于 Python 的类型提示功能,能快速高效地开发 API。安装 FastAPI 和uvicorn(用于运行 FastAPI 应用)后,编写如下代码创建一个接口:

from fastapi import FastAPI
from pydantic import BaseModelapp = FastAPI()class Item(BaseModel):name: strprice: float@app.post('/api/item/')
def create_item(item: Item):return {'item': item.dict(),'message': 'Item created successfully'}if __name__ == '__main__':import uvicornuvicorn.run(app, host='0.0.0.0', port = 8000)

(二)RPC 接口实现

1. XML - RPC

Python 标准库中提供了xmlrpc模块,用于实现 XML - RPC。它使用 XML 格式在网络上传输数据,是一种简单且跨语言的 RPC 解决方案。以下是一个简单的 XML - RPC 服务器和客户端示例:

服务端

from xmlrpc.server import SimpleXMLRPCServerdef add_numbers(a, b):return a + bserver = SimpleXMLRPCServer(('localhost', 8000))
print("Listening on port 8000...")
server.register_function(add_numbers, 'add')
server.serve_forever()

客户端

import xmlrpc.clientproxy = xmlrpc.client.ServerProxy('http://localhost:8000')
result = proxy.add(3, 5)
print(f"The result of addition is: {result}")

2. json-rpc

与 XML - RPC 类似,但使用 JSON 格式传输数据,在数据量和解析效率上更具优势。jsonrpclib - simple是 Python 中常用的 JSON - RPC 库。以下是一个简单示例:

服务器

from flask import Flask
from jsonrpclib.SimpleJSONRPCServer import SimpleJSONRPCServerapp = Flask(__name__)
server = SimpleJSONRPCServer(('localhost', 8001))def multiply_numbers(a, b):return a * bserver.register_function(multiply_numbers,'multiply')@app.route('/')
def index():return "JSON - RPC Server is running"if __name__ == '__main__':server_thread = threading.Thread(target=server.serve_forever)server_thread.start()app.run(debug=True)

客户端

import jsonrpclibserver = jsonrpclib.Server('http://localhost:8001')
result = server.multiply(4, 6)
print(f"The result of multiplication is: {result}")

3. gRPC

由 Google 开发的高性能 RPC 框架,它使用 Protocol Buffers 作为接口定义语言和数据序列化格式。在 Python 中使用 gRPC,首先需要定义.proto文件来描述服务和消息结构,然后通过工具生成 Python 代码。以下是一个简单的步骤示例:

定义proto:

syntax = "proto3";package helloworld;service Greeter {rpc SayHello(HelloRequest) returns (HelloReply) {}
}message HelloRequest {string name = 1;
}message HelloReply {string message = 1;
}

使用protoc工具生成 Python 代码

服务器代码:

import time
import grpc
from concurrent import futures
import helloworld_pb2
import helloworld_pb2_grpcclass Greeter(helloworld_pb2_grpc.GreeterServicer):def SayHello(self, request, context):return helloworld_pb2.HelloReply(message=f"Hello, {request.name}!")def serve():server = grpc.server(futures.ThreadPoolExecutor(max_workers = 10))helloworld_pb2_grpc.add_GreeterServicer_to_server(Greeter(), server)server.add_insecure_port('[::]:50051')server.start()try:while True:time.sleep(86400)except KeyboardInterrupt:server.stop(0)if __name__ == '__main__':serve()

客户端

import grpc
import helloworld_pb2
import helloworld_pb2_grpcdef run():channel = grpc.insecure_channel('localhost:50051')stub = helloworld_pb2_grpc.GreeterStub(channel)request = helloworld_pb2.HelloRequest(name='Python Client')response = stub.SayHello(request)print("Greeter client received: " + response.message)if __name__ == '__main__':run()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/33908.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C/C++算法】从浅到深学习--- 前缀和算法(图文兼备 + 源码详解)

绪论&#xff1a;冲击蓝桥杯一起加油&#xff01;&#xff01; 每日激励&#xff1a;“不设限和自我肯定的心态&#xff1a;I can do all things。 — Stephen Curry” 绪论​&#xff1a; 本章将使用八道题由浅到深的带你了解并基本掌握前缀和思想&#xff0c;以及前缀和的基…

脑电:时域分析(任务态)

时域分析&#xff1a;时间序列&#xff08;时域信号&#xff09; EEG和ERP都是时间序列 ERP&#xff1a;事件诱发的电位是随着时间变化 组水平&#xff1a;需要这一组的个体不能差异性太大。 提值的指标&#xff0c;选取平均幅值确定成分的显著情况 mean(EEG.data,3): 在第…

【C语言】自定义类型:结构体,联合,枚举(下)

前言&#xff1b;上一期我们侧重讲了一个非常重要的自定义类型结构体&#xff0c;这一期我们来说说另外两种自定义类型&#xff1a;联合&#xff0c;和枚举。 传送门&#xff1a;自定义类型&#xff1a;结构体&#xff0c;联合&#xff0c;枚举(上) 文章目录 一&#xff0c;联…

数组的介绍

1.数组的概念 数组是一组相同类型元素的集合&#xff0c;从这个描述中我们知道&#xff1a; 数组中存放1个或多个数据&#xff0c;但是数组的元素个数不为0。数组中存放的多个数据&#xff0c;类型是相同的。 数组分为一维数组和多维数组&#xff0c;多维数组一般比较多见的…

蓝桥杯 17110抓娃娃

问题描述 小明拿了 n 条线段练习抓娃娃。他将所有线段铺在数轴上&#xff0c;第 i 条线段的左端点在 li&#xff0c;右端点在 ri​。小明用 m 个区间去框这些线段&#xff0c;第 i个区间的范围是 [Li​, Ri​]。如果一个线段有 至少一半 的长度被包含在某个区间内&#xff0c;…

linux ptrace 图文详解(二) PTRACE_TRACEME 跟踪程序

目录 一、基础介绍 二、PTRACE_TRACE 实现原理 三、代码实现 四、总结 &#xff08;代码&#xff1a;linux 6.3.1&#xff0c;架构&#xff1a;arm64&#xff09; One look is worth a thousand words. —— Tess Flanders 一、基础介绍 GDB&#xff08;GNU Debugger&…

记录致远OA服务器硬盘升级过程

前言 日常使用中OA系统突然卡死&#xff0c;刷新访问进不去系统&#xff0c;ping服务器地址正常&#xff0c;立马登录服务器检查&#xff0c;一看磁盘爆了。 我大脑直接萎缩了&#xff0c;谁家OA系统配400G的空间啊&#xff0c;过我手的服务器没有50也是30台&#xff0c;还是…

电网电压暂态扰动机理与工业设备抗失压防护策略研究

什么是晃电&#xff1f; 国标GB/T 30137-2013 中定义:工频电压方均根值突然降至额定值的90%~10%&#xff0c;持续时间为10ms~1min后恢复正常的现象。Acrel8757V 晃电的原因 1.系统侧因素 短路故障&#xff1a;雷击、线路接地、设备误碰等导致电网短路&#xff0c;故障点电压…

Linux监控网络状态

一、基本介绍 1、基本语法 netstat [选项] 2、常用选项 选项 说明 -a 显示所有连接和监听的套接字&#xff08;包括TCP、UDP&#xff09;。 -t 显示 TCP 连接。 -u 显示 UDP 连接。 -l 显示正在监听的套接字&#xff08;server端&#xff09;。 -n 显示数字格式的…

UE5以插件的形式加载第三方库

之前在UE中加载第三方库的形式是以静态或者动态链接的形式加载但是不太容易复用。就想着能不能以插件的形式加载第三方库&#xff0c;这样直接把插件打包发行就可以复用了&#xff0c;之前也找过相应的教程但是很难找到比较简单易懂的教程&#xff0c;要么是比较复杂&#xff0…

Go执行当前package下的所有方法

需求&#xff1a;需要一个文件一个定时任务方法&#xff0c;当项目初始化完毕后&#xff0c;自动加载并执行这些定时任务方法 项目目录架构 main.go 初始化 package mainimport ("sql_demo/schedule" )func main() {/***** 其他初始化完毕后的操作**/// 定时任务sc…

AnyAnomaly: 基于大型视觉语言模型的零样本可定制视频异常检测

文章目录 速览摘要1. 引言2. 相关工作视频异常检测大型视觉语言模型&#xff08;LVLMs&#xff09; 3. 方法3.1. 总览3.2. 关键帧选择模块3.3. 上下文生成基于 WinCLIP 的注意力机制网格图像生成 3.4. 异常检测提示词设计异常评分 4. 实验4.1. 数据集4.2. 评估标准4.3. 结果4.4…

【AWS入门】2025 AWS亚马逊云科技账户注册指南

【AWS入门】2025 AWS亚马逊云科技账户注册指南 A Guide To Register a New account on AWS By JacksonML 0. AWS亚马逊云科技简介 Amazon Web Service(AWS) 即亚马逊云科技&#xff0c;其在全球Cloud Computing(云计算)市场占有最为重要的地位。 AWS连续13年被Gartner评为…

Spring 中 SmartInitializingSingleton 的作用和示例

一、 接口定义 SmartInitializingSingleton 是 Spring 框架提供的一个 单例 Bean 全局初始化回调接口&#xff0c;用于在 所有非延迟单例 Bean 初始化完成后 执行自定义逻辑。 核心方法&#xff1a; public interface SmartInitializingSingleton {void afterSingletonsInsta…

element tree树形结构默认展开全部

背景&#xff1a; el-tree树形结构&#xff0c;默认展开全部&#xff0c;使用属性default-expand-all【是否默认展开所有节点】&#xff1b;默认展开一级&#xff0c;设置default-expanded-keys【默认展开的节点的 key 的数组】属性值为数组。 因为我这里的数据第一级是四川【省…

大数据-spark3.5安装部署之local模式

spark&#xff0c;一个数据处理框架和计算引擎。 下载 local模式即本地模式&#xff0c;就是不需要任何其他节点资源就可以在本地执行spark代码的环境。用于练习演示。 上传解压 使用PortX将文件上传至/opt 进入/opt目录&#xff0c;创建目录module&#xff0c;解压文件至/o…

Discuz建站教程之论坛头部logo跳转链接怎么修改?

在修改头部logo跳转链接前&#xff0c;我们需要知道对应代码在哪个文件目录&#xff0c;进入宝塔或是服务器&#xff0c;找到文件&#xff1a;\template\default\common\header.htm&#xff0c;编辑器打开&#xff0c;搜索以下代码&#xff0c;大概在135行 <a href"{i…

【FreeRTOS】FreeRTOS操作系统在嵌入式单片机上裸机移植

目录 一 RTOS概述 二 FreeRTOS移植 三 FreeRTOS使用 四 附录 一 RTOS概述 先了解一些基础概念,以下内容摘自FreeRTOS官网(FreeRTOS™ - FreeRTOS™): 【1】RTOS基础知识 实时操作系统 (RTOS) 是一种体积小巧、确定性强的计算机操作系统。 RTOS 通常用于需要在严格时间限…

编译支持 RKmpp 和 RGA 的 ffmpeg 源码

一、前言 RK3588 支持VPU硬件解码&#xff0c;需要rkmpp进行调用&#xff1b;支持2D图像加速&#xff0c;需要 RGA 进行调用。 这两个库均能通过 ffmpeg-rockchip 进行间接调用&#xff0c;编译时需要开启对应的功能。 二、依赖安装 编译ffmpeg前需要编译 rkmpp 和 RGA&#xf…

深度学习基础:线性代数本质2——线性组合、张成的空间与基

目录 一、线性组合 1. 用一个有趣的角度看向量坐标 2. 如果我们选择不同的基向量会怎样&#xff1f; 3. 线性组合 4. 张成的空间 ① 二维向量的张成的空间 ② 三维向量的张成的空间​编辑 5.线性相关 6.线性无关 7. 基的定义 一、线性组合 1. 用一个有趣的角度看向量坐…