为什么说Python 是胶水语言?
"Python 是胶水语言"这一说法是指它很擅长将不同的程序或代码库连接在一起,能够让来自不同编程语言或框架的组件无缝协作。Python 具有丰富的库和简单的语法,使得它可以轻松调用其他语言编写的程序或使用不同技术栈的模块。
以下是几个具体的实例,展示了Python 作为胶水语言的特性:
实例 1:调用 C/C++ 代码
使用ctypes
库可以方便地调用 C 函数。
假设有一个简单的 C 函数:
// example.c
#include <stdio.h>int add(int a, int b) {return a + b;
}void say_hello() {printf("Hello, World!\n");
}
采用编译它为共享库:
gcc -shared -o libexample.so -fPIC example.c
然后用 Python 调用这个库:
# example.py
import ctypes# 加载共享库
lib = ctypes.CDLL('./libexample.so')# 定义函数原型
lib.add.argtypes = (ctypes.c_int, ctypes.c_int) # 表示该函数接收两个整数参数
lib.add.restype = ctypes.c_int # 设置 `add` 函数的返回类型# 调用 C 函数
result = lib.add(3, 5)
print(f'Result of add(3, 5): {result}')# 调用无参数 C 函数
lib.say_hello()
运行这个 Python 脚本,你会看到:
实例 2:集成数据库和 Web 服务
Python 强大的库生态,使得它在集成不同技术栈方面非常有优势。例如,连接一个数据库并通过 Flask 框架提供一个简单的 Web API。
# Install required packages:
# pip install flask sqlalchemyfrom flask import Flask, jsonify, request
from sqlalchemy import create_engine, Column, Integer, String, Sequence
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmakerapp = Flask(__name__)
Base = declarative_base()# 创建数据库表 User(id, name, age)
class User(Base):__tablename__ = 'users'id = Column(Integer, Sequence('user_id_seq'), primary_key=True)name = Column(String(50))age = Column(Integer)# 使用的是 SQLite 文件数据库,数据存储到本地文件中,程序结束后数据也会被保留engine = create_engine('sqlite:///mydatabase.db') # 使用文件存储的 SQLite 数据库
Base.metadata.create_all(engine) # 创建所有的表Session = sessionmaker(bind=engine) # 这个Session对象实际上是一个数据库会话或连接,它用于执行数据库操作(如查询、插入、更新、删除等)。
session = Session()# 添加一些数据
new_user = User(name='Bobo', age=52)
session.add(new_user)
session.commit()@app.route('/users', methods=['GET'])
def get_users():users = session.query(User).all()return jsonify([{'id': user.id, 'name': user.name, 'age': user.age} for user in users])@app.route('/user', methods=['POST'])
def add_user():data = request.jsonnew_user = User(name=data['name'], age=data['age'])session.add(new_user)session.commit()return jsonify({'id': new_user.id})if __name__ == '__main__':app.run(debug=True)
这个脚本使用 SQLAlchemy
连接 SQLite 数据库,并且通过 Flask 框架提供了一个 Web 接口。运行这个脚本并访问 http://127.0.0.1:5000/users
获取表中记录信息。
使用 http://127.0.0.1:5000/user
,访问在本程序中会出现如下错误,出现如下 Method Not Allowed
。 错误的原因是因为 HTTP 方法错误。访问 URL http://127.0.0.1:5000/user
时,浏览器默认使用 GET 方法请求,而代码中,/user
端点只允许 POST 方法。
我们可以使用cURL
来发送POST请求:
结合之前的 Flask 示例,我们可以使用 cURL 向我们的 Flask 应用发送一个 POST 请求来添加用户:在 Git Bash
curl -X POST -H "Content-Type: application/json" -d '{"name": "Bo", "age": 30}' http://127.0.0.1:5000/user在 Windows 命令提示符(CMD)或 PowerShell
curl -X POST -H "Content-Type: application/json" -d "{\"name\": \"Bobo\", \"age\": 30}" http://127.0.0.1:5000/user注意:
1. 双引号问题:在 Windows CMD 中,双引号会被用来包裹整个字符串,内部的双引号需要进行转义。
2. 单引号和双引号的区别:在 Unix 风格的 Shell(如 Git Bash)中,你可以使用单引号包裹整个字符串,JSON 字符串内部的引号不需要转义。建议用Git Bash来测试
第二个实例展示了如何利用Python作为胶水语言,将不同的技术和组件集成在一起进行协作。具体来说,它通过几个方面体现了Python的胶水作用:
1. 数据库连接与操作
在该实例中,使用了SQLAlchemy
库与SQLite数据库进行连接和操作。SQLAlchemy
是Python中一个非常强大的ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库。
代码片段:
from flask import Flask, jsonify, request
from sqlalchemy import create_engine, Column, Integer, String, Sequence
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmakerapp = Flask(__name__)
Base = declarative_base()# 创建数据库表 User(id, name, age)
class User(Base):__tablename__ = 'users'id = Column(Integer, Sequence('user_id_seq'), primary_key=True)name = Column(String(50))age = Column(Integer)# 使用的是 SQLite 文件数据库,数据存储到本地文件中,程序结束后数据也会被保留engine = create_engine('sqlite:///mydatabase.db') # 使用文件存储的 SQLite 数据库
Base.metadata.create_all(engine) # 创建所有的表Session = sessionmaker(bind=engine) # 这个Session对象实际上是一个数据库会话或连接,它用于执行数据库操作(如查询、插入、更新、删除等)。
session = Session()# 添加一些数据
new_user = User(name='Bobo', age=52)
session.add(new_user)
session.commit()
2. 提供Web服务
实例中使用了Flask
框架来提供Web服务。Flask
是一个轻量级的Web应用框架,适合快速开发和部署Web应用。通过Flask
框架,可以轻松定义API端点,并处理HTTP请求和响应。
代码片段:
@app.route('/users', methods=['GET'])
def get_users():users = session.query(User).all()return jsonify([{'id': user.id, 'name': user.name, 'age': user.age} for user in users])@app.route('/user', methods=['POST'])
def add_user():data = request.jsonnew_user = User(name=data['name'], age=data['age'])session.add(new_user)session.commit()return jsonify({'id': new_user.id})if __name__ == '__main__':app.run(debug=True)
3. 数据格式转换
通过jsonify
函数,实例实现了将Python对象(如列表和字典)转换为JSON格式的HTTP响应。这体现了Python在数据格式转换和处理方面的灵活性。
代码片段:
from flask import jsonify@app.route('/users', methods=['GET'])
def get_users():users = session.query(User).all()return jsonify([{'id': user.id, 'name': user.name, 'age': user.age} for user in users])
4. 跨模块和库的协作
该实例展示了如何将不同功能的库和模块结合在一起工作。比如,Flask
负责处理Web请求和响应,而SQLAlchemy
负责数据库操作。Python通过其简单的语法和强大的库生态,使得整合这些组件变得非常方便和高效。
5. 使用第三方库
SQLAlchemy
和 Flask 都是Python的第三方库,Python的胶水功能在这里表现为它能够无缝地集成和使用这些库以实现复杂的功能,而不需要开发者编写大量的底层代码。
综上所述,这个实例在数据库连接与操作、提供Web服务、数据格式转换、不同模块和库的协作以及第三方库的使用方面,展示了Python作为胶水语言将各种不同技术和组件整合起来的强大能力。
实例 3:控制和管理系统进程
通过 Python 提供的 subprocess
库,你可以轻松地调用和管理系统进程。
import subprocess# 运行一个简单的系统命令适用于Windows平台
result = subprocess.run(['cmd', '/c', 'dir'], capture_output=True, text=True) # 使用cmd命令解释器,并通过 `/c` 参数执行 `dir` 命令。
print(result.stdout)# 运行另一个 Python 脚本
result = subprocess.run(['python', 'other_script.py'], capture_output=True, text=True)
print(result.stdout)
第三个实例展示了如何使用 Python 的 subprocess
模块来调用和管理系统级别的命令和其他 Python 脚本。这些功能在以下几个方面展示了 Python 作为胶水语言的能力:
1. 调用系统命令
Python 可以通过 subprocess
模块轻松地调用和执行系统命令。这使得 Python 能够扮演脚本语言的角色,用于自动化各种系统管理任务,与操作系统直接交互。
import subprocess# 运行一个简单的系统命令适用于Windows平台
result = subprocess.run(['cmd', '/c', 'dir'], capture_output=True, text=True) # 使用cmd命令解释器,并通过 `/c` 参数执行 `dir` 命令。
print(result.stdout)
在这个例子中,Python 调用系统自带的dir
/c命令,列出当前目录下的文件并将结果输出。这展示了 Python 与操作系统之间的无缝集成。
2. 执行其他 Python 脚本
除了系统命令,Python 还可以调用其他 Python 脚本,执行这些脚本并捕获其输出。这使得 Python 可以作为主调度器,将多个 Python 脚本整合到一个更大的应用程序或工作流程中。
# 运行另一个 Python 脚本
result = subprocess.run(['python', 'other_script.py'], capture_output=True, text=True)
print(result.stdout)
这个例子展示了如何通过 Python 调用另一个 Python 脚本 other_script.py
并获取其输出。这在多脚本项目或分布式系统中尤其有用。
3. 捕获和处理外部命令的输出
通过 capture_output=True
和 text=True
参数,Python 可以捕获并直接处理外部命令的输出,便于后续的逻辑处理或数据分析。这使得 Python 可以整合外部工具的功能,将它们的输出纳入到整个应用程序的工作流程中。
# 运行一个简单的系统命令适用于Windows平台
result = subprocess.run(['cmd', '/c', 'dir'], capture_output=True, text=True)
print(result.stdout)
在这个例子中,Python 捕获了 ls -l
命令的输出,并将其作为字符串处理和打印。
4. 统一的错误处理机制
subprocess
模块还提供了统一的错误处理机制。当外部命令失败时,Python 可以捕获错误信息并进行相应的处理。这使得错误管理变得更加简单和一致。
try:result = subprocess.run(['some_non_existing_command'], capture_output=True, text=True, check=True)
except subprocess.CalledProcessError as e:print(f"Command failed with exit status {e.returncode}")print(e.output)
在这个例子中,如果外部命令失败,Python 可以捕获异常并处理错误信息,提供更好的错误管理能力。
5. 平台独立性
Python 的 subprocess
模块是跨平台的,这意味着同样的代码可以在不同操作系统上运行,而不需要做多余的修改。这极大地提高了代码的可移植性和维护性。
import subprocess# 运行一个简单的系统命令 Linux下
result = subprocess.run(['ls', '-l'], capture_output=True, text=True)
print(result.stdout)
无论是在 Linux、macOS 还是 Windows,这段代码都能够工作(在 Windows 上需要将 ls -l
换成相应的命令,例如 dir
)。
6. 管道和数据流
subprocess
模块允许我们通过管道将不同进程的输入和输出连接起来,形成数据流。这使得 Python 可以将多个独立的程序组合起来,共同完成一个复杂任务。
# Example: Using pipeline
import subprocess
# 第一阶段:使用 echo 产生文本
# 我们使用 cmd 来调用 echo,因为 echo 是 cmd 的内置命令
cmd1 = ['cmd', '/c', 'echo Hello, World! This is a test.']
# 第二阶段:使用 findstr 查找特定单词
cmd2 = ['findstr', 'World'] # findstr 在 Windows 上用它来查找文本
# 运行第一个命令
result1 = subprocess.run(cmd1, stdout=subprocess.PIPE, text=True)
# 将第一个命令的输出作为输入传递给第二个命令
result2 = subprocess.run(cmd2, input=result1.stdout, capture_output=True, text=True)
# 打印第二个命令的输出
print("Filtered output:", result2.stdout)
在这个实例中,使用了 Windows 平台下的 cmd
和 findstr
命令,演示了如何通过管道将一个命令的输出传递给另一个命令。这种方式在 Windows 平台上非常实用,可以有效地实现数据流处理和命令的组合使用。
第三个实例通过调用系统命令、执行其他 Python 脚本、捕获和处理外部命令的输出、统一的错误处理机制、平台独立性以及管道和数据流的使用,充分展示了 Python 作为胶水语言的强大能力。它能够将不同的工具和组件无缝地集成到一个统一的工作流程中,提高开发效率和代码的可维护性。
小结
从调用底层的高效 C/C++ 代码,到无缝集成数据库操作及 web 服务,再到进行复杂的系统级别命令管理和数据流处理,Python 出色地充当了“胶水”的角色,把各自独立的发展语言、工具和技术整合到一个统一的环境中。
-
与多种语言和技术的无缝整合: 不管是与 C/C++ 库交互,还是与数据库或 Web 服务的整合,Python 都能够轻松完成。
丰富的库和框架支持:
SQLAlchemy
、Flask
、ctypes
和subprocess
等强大的三方库和框架让 Python 的集成功能变得平易近人。 -
简洁优雅的语法: 简单而清晰的语法使开发者能够迅速编写和调试代码,提高开发效率。
-
跨平台: Python 脚本在 Windows、macOS 和 Linux 环境下都能无缝运行,使其成为跨平台开发的理想选择。
因此,Python 作为“胶水语言”不仅是在技术上的能力,更在于它通过简洁优雅的编程方式,将不同的技术轻松连接在一起,使开发者得以在复杂的技术栈中游刃有余。
相关文章:

为什么说Python 是胶水语言?
"Python 是胶水语言"这一说法是指它很擅长将不同的程序或代码库连接在一起,能够让来自不同编程语言或框架的组件无缝协作。Python 具有丰富的库和简单的语法,使得它可以轻松调用其他语言编写的程序或使用不同技术栈的模块。 以下是几个…...

GitLab教程(二):快速上手Git
文章目录 1.将远端代码克隆到本地2.修改本地代码并提交到远程仓库3.Git命令总结git clonegit statusgit addgit commitgit pushgit log 首先,我在Gitlab上创建了一个远程仓库,用于演示使用Gitlab进行版本管理的完整流程: 1.将远端代码克隆到本…...
结构体知识点
基本概念 结构体是一种自定义变量类型,类似于枚举需要自己定义。 它是数据和函数的集合。 在结构体中,可以声明各种变量和方法。 基本语法 1.结构体一般写在namespace语句块中。 2.结构体关键字struct struct 自定义结构体名 {//第一部分//变量//…...
C# —— 显示转换
显示转换: 通过一些方法可以将其他数据类型转换为我们想要的数据类型 1.括号强转 作用: 一般情况下 将高精度的类型转换为低精度 // 语法: 变量类型 变量名 (转换的变量类型名称) 变量; // 注意: 精度问题 范围问题 sbyte sb 1; short s 1; int …...

zip加密txt文件后,暴力破解时会有多个解密密码可以打开的疑问??
最近在做一个关于zip压缩文件解密的测试,发现通过暴力解密时,会有多个解密密码可以打开,非常疑惑,这里做个问题,希望能有大佬解惑。 1、首先在本地创建一个113449.txt的文件,然后右键txt文件选择压缩&…...

css入门宝典
3.1.4 通配符选择器 语法 : *{} 作用 : 让页面中所有的标签执行该样式,通常用来清除间距 例子 : *{ margin: 0; //外间距 padding: 0; //内间距 } 一 CSS基本语法 1基础知识 1.1概述 Css (层叠样式表)是种格式化网页的标准方式, 用于控制设置网页的样式ÿ…...
【AI原理解析】— 星火大模型
目录 1. 模型基础架构 神经网络结构 编码器 解码器 多层神经网络结构 其他自然语言处理技术 2. 训练数据 来源 规模 3. 自监督学习 Masked Language Model (MLM) 4. 参数量与计算能力 大规模参数量 深度学习算法 5. 技术特点 多模态输入 自我学习与迭代 6. 应…...

StarNet实战:使用StarNet实现图像分类任务(一)
文章目录 摘要安装包安装timm 数据增强Cutout和MixupEMA项目结构计算mean和std生成数据集 摘要 https://arxiv.org/pdf/2403.19967 论文主要集中在介绍和分析一种新兴的学习范式——星操作(Star Operation),这是一种通过元素级乘法融合不同子…...

单链表——AcWing.826单链表
单链表 定义 单链表是一种常见的数据结构,它由一系列节点组成,每个节点包含一个数据元素和一个指向下一个节点的指针。 运用情况 用于实现动态的数据存储和管理,例如实现栈、队列等其他数据结构。在需要频繁进行插入和删除操作时非常有用…...
10:Hello, World!的大小
OpenJudge - 10:Hello, World!的大小 描述 还记得在上一章里,我们曾经输出过的“Hello, World!”吗? 它虽然不是本章所涉及的基本数据类型的数据,但我们同样可以用sizeof函数获得它所占用的空间大小。 请编程求出它的大小,看看跟你…...

【Pandas驯化-03】Pandas中常用统计函数mean、count、std、info使用
【Pandas驯化-03】Pandas中常用统计函数mean、count、std、info使用 本次修炼方法请往下查看 🌈 欢迎莅临我的个人主页 👈这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合,智慧小天地! 🎇 相关内容文档获取 微…...

WordPress——Argon主题美化
文章目录 Argon主题美化插件类类别标签页面更新管理器文章头图URL查询监视器WordPress提供Markdown语法评论区头像设置发信设置隐藏登陆备份设置缓存插件 主题文件编辑器页脚显示在线人数备案信息(包含备案信息网站运行时间)banner下方小箭头滚动效果站点功能概览下方Links功能…...

Vue部分文件说明
1.eslintignore文件 Eslint会忽略的文件 # Eslint 会忽略的文件.DS_Store node_modules dist dist-ssr *.local .npmrc 2.gitignore # Git 会忽略的文件.DS_Store node_modules dist dist-ssr .eslintcache# Local env files *.local# Logs logs *.log npm-debug.log* yarn-de…...

图书管理系统(SpringBoot+SpringMVC+MyBatis)
目录 1.数据库表设计 2.引入MyBatis和MySQL驱动依赖 3.配置数据库&日志 4.Model创建 5.用户登录功能实现 6.实现添加图书功能 7.实现翻页功能 1.数据库表设计 数据库表是应⽤程序开发中的⼀个重要环节, 数据库表的设计往往会决定我们的应⽤需求是否能顺利实现, 甚至决…...

11.泛型、trait和生命周期(上)
标题 一、泛型数据的引入二、改写为泛型函数三、结构体/枚举中的泛型定义四、方法定义中的泛型 一、泛型数据的引入 下面是两个函数,分别用来取得整型和符号型vector中的最大值 use std::fs::File;fn get_max_float_value_from_vector(src: &[f64]) -> f64…...

UML与设计模式
1、关联关系 关联关系用于描述不同类的对象之间的结构关系,它在一段时间内将多个类的实例连接在一起。关联关系是一种静态关系,通常与运行状态无关,而是由“常识”、“规则”、“法律”等因素决定的,因此关联关系是一种强关联的关…...

如何在Spring Boot中实现图片上传至本地和阿里云OSS
在开发Web应用时,处理文件上传是常见的需求之一,尤其是在涉及到图片、视频等多媒体数据时。本文将详细介绍如何使用Spring Boot实现图片上传至本地服务器以及阿里云OSS存储服务,并提供完整的代码示例。 一、上传图片至本地 首先,…...

几个小创新模型,KAN组合网络(LSTM、GRU、Transformer)时间序列预测,python预测全家桶...
截止到本期,一共发了8篇关于机器学习预测全家桶Python代码的文章。参考往期文章如下: 1.终于来了!python机器学习预测全家桶 2.机器学习预测全家桶-Python,一次性搞定多/单特征输入,多/单步预测!最强模板&a…...

ubuntu18.04 配置 mid360并测试fast_lio
1.在买到Mid360之后,我们可以看到mid360延伸出来了三组线。 第一组线是电源线,包含了红色线正极,和黑色线负极。一般可以用来接9-27v的电源,推荐接12v的电源转换器,或者接14.4v的电源转换器。 第二组线是信号线&#x…...

基于Java的诊所医院管理系统,springboot+html,MySQL数据库,用户+医生+管理员三种身份,完美运行,有一万一千字论文
演示视频 基本介绍 基于Java的诊所医院管理系统,springboothtml,MySQL数据库,用户医生管理员三种身份,完美运行,有一万一千字论文。 用户:个人信息管理、预约医生、查看病例、查看公告、充值、支付费用...…...

C++初阶-list的底层
目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...

初学 pytest 记录
安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...

AI病理诊断七剑下天山,医疗未来触手可及
一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...

使用Spring AI和MCP协议构建图片搜索服务
目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式(本地调用) SSE模式(远程调用) 4. 注册工具提…...
08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险
C#入门系列【类的基本概念】:开启编程世界的奇妙冒险 嘿,各位编程小白探险家!欢迎来到 C# 的奇幻大陆!今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类!别害怕,跟着我,保准让你轻松搞…...

【C++进阶篇】智能指针
C内存管理终极指南:智能指针从入门到源码剖析 一. 智能指针1.1 auto_ptr1.2 unique_ptr1.3 shared_ptr1.4 make_shared 二. 原理三. shared_ptr循环引用问题三. 线程安全问题四. 内存泄漏4.1 什么是内存泄漏4.2 危害4.3 避免内存泄漏 五. 最后 一. 智能指针 智能指…...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...

【 java 虚拟机知识 第一篇 】
目录 1.内存模型 1.1.JVM内存模型的介绍 1.2.堆和栈的区别 1.3.栈的存储细节 1.4.堆的部分 1.5.程序计数器的作用 1.6.方法区的内容 1.7.字符串池 1.8.引用类型 1.9.内存泄漏与内存溢出 1.10.会出现内存溢出的结构 1.内存模型 1.1.JVM内存模型的介绍 内存模型主要分…...

水泥厂自动化升级利器:Devicenet转Modbus rtu协议转换网关
在水泥厂的生产流程中,工业自动化网关起着至关重要的作用,尤其是JH-DVN-RTU疆鸿智能Devicenet转Modbus rtu协议转换网关,为水泥厂实现高效生产与精准控制提供了有力支持。 水泥厂设备众多,其中不少设备采用Devicenet协议。Devicen…...
0x-3-Oracle 23 ai-sqlcl 25.1 集成安装-配置和优化
是不是受够了安装了oracle database之后sqlplus的简陋,无法删除无法上下翻页的苦恼。 可以安装readline和rlwrap插件的话,配置.bahs_profile后也能解决上下翻页这些,但是很多生产环境无法安装rpm包。 oracle提供了sqlcl免费许可,…...