在ubuntu上用Python的openpyxl模块操作Excel的案例
文章目录
- 安装模块
- 读取Excel
- 数据库取数
- 匹配数据和更新Excel数据
在Ubuntu系统的环境下基本职能借助Python的openpyxl模块实现对Excel数据的操作。
安装模块
本次需要用到的模块需要提前安装(如果没有的话)
pip3 install openpyxl
pip3 install pymysql
在操作前,需要准备好用于操作的Excel文件,假设其文件名为 example.xlsx。
此外,还需准备好相应的数据库,本文以MySQL 5.7数据库为例,确保数据库中包含相应的数据表及数据。
读取Excel
使用openpyxl模块读取Excel文件中的数据,可参考以下代码示例:
from openpyxl import load_workbook# 加载Excel文件
workbook = load_workbook('example.xlsx')# 选择活动工作表
sheet = workbook.active# 读取数据并存储
rows = sheet.max_row
cols = sheet.max_column
data_list = []
for row in range(1, rows + 1):row_data = []for col in range(1, cols + 1):cell_value = sheet.cell(row=row, column=col).valuerow_data.append(cell_value)data_list.append(row_data)# 显示读取的数据
for row in data_list:print(row)
上述代码将Excel文件中的数据读取并存储到 data_list 列表中,以便后续与数据库数据进行匹配。
数据库取数
以下是连接数据库并进行简单查询的代码示例:
import pymysql# 连接数据库
connection = pymysql.connect(host='localhost',user='root',password='your_password',database='your_database',charset='utf8mb4',cursorclass=pymysql.cursors.DictCursor
)try:with connection.cursor() as cursor:# 查询数据search_value = data_list[0][0] # 以data_list第一个元素的第一列的值作为搜索条件sql = "SELECT * FROM your_table WHERE some_column = %s"cursor.execute(sql, (search_value,))result = cursor.fetchall()# 显示匹配结果for row in result:print(row)
finally:connection.close()
在使用过程中,需要根据实际情况修改连接参数及查询语句中的相关字段。
匹配数据和更新Excel数据
假设匹配到的数据存储在 result 列表中,现在需要将匹配结果更新回Excel数据中,具体操作如下:
from openpyxl import Workbook# 创建新的工作簿
workbook = load_workbook('example.xlsx')
sheet = workbook.active# 写入表头信息
sheet['A'] = '原数据'
sheet['B'] = '匹配结果'# 将原数据和新列写入Excel
for i, row in enumerate(data_list, start=1):sheet.cell(row=i, column=1).value = rowmatched = Falsefor res in result:if row[0] == res['col']: # 假设匹配字段在第一列且数据库查询结果字段名为'col'sheet.cell(row=i, column=2).value = '匹配成功'matched = Truebreakif not matched:sheet.cell(row=i, column=2).value = '无匹配数据'# 保存更新后的新工作簿
workbook.save('matched_data.xlsx')

相关文章:
在ubuntu上用Python的openpyxl模块操作Excel的案例
文章目录 安装模块读取Excel数据库取数匹配数据和更新Excel数据 在Ubuntu系统的环境下基本职能借助Python的openpyxl模块实现对Excel数据的操作。 安装模块 本次需要用到的模块需要提前安装(如果没有的话) pip3 install openpyxl pip3 install pymysql在操作前,需…...
【OS安装与使用】part6-ubuntu 22.04+CUDA 12.4运行MARL算法(多智能体强化学习)
文章目录 一、待解决问题1.1 问题描述1.2 解决方法 二、方法详述2.1 必要说明2.2 应用步骤2.2.1 下载源码并安装2.2.2 安装缺失的依赖项2.2.3 训练执行MAPPO算法实例 三、疑问四、总结 一、待解决问题 1.1 问题描述 已配置好基础的运行环境,尝试运行MARL算法。 1…...
【Python爬虫(35)】解锁Python多进程爬虫:高效数据抓取秘籍
【Python爬虫】专栏简介:本专栏是 Python 爬虫领域的集大成之作,共 100 章节。从 Python 基础语法、爬虫入门知识讲起,深入探讨反爬虫、多线程、分布式等进阶技术。以大量实例为支撑,覆盖网页、图片、音频等各类数据爬取ÿ…...
HarmonyOS 开发套件 介绍 ——上篇
HarmonyOS 开发套件 介绍 ——上篇 在当今科技飞速发展的时代,操作系统作为智能设备的核心,其重要性不言而喻。而HarmonyOS,作为华为推出的全新操作系统,正以其独特的魅力和强大的功能,吸引着越来越多的开发者和用户的…...
Linux 高级篇 日志管理、定制自己的Linux系统、备份与恢复
一、日志管理 (1)基本介绍 日志文件是重要的系统信息文件,记录了如用户登录、系统启动、系统安全、邮件及各种服务等相关重要系统事件在安全方面,日志也至关重要,它能记录系统日常发生的各类事情,可用于检…...
deepseek与其他大模型配合组合
DeepSeek与其他大模型的配合组合,展现了其在多个领域中的强大应用潜力和灵活性。以下是对DeepSeek与其他大模型配合组合的详细分析: 一、DeepSeek与华知大模型的组合 背景介绍: 华知大模型是同方知网与华为联手打造的,具备全学科…...
经验分享—WEB渗透测试中遇到加密内容的数据包该如何测试!
经验分享—WEB渗透测试中遇到加密内容的数据包该如何测试! 01 加解密的意义 现阶段的渗透测试让我发现越来越多的系统不只是在漏洞修补方面做了功夫,还对一些参数进行加密,干扰爬虫或者渗透测试的进行。 在我小白阶段看到下图这种加密方式…...
JUC并发—9.并发安全集合四
大纲 1.并发安全的数组列表CopyOnWriteArrayList 2.并发安全的链表队列ConcurrentLinkedQueue 3.并发编程中的阻塞队列概述 4.JUC的各种阻塞队列介绍 5.LinkedBlockingQueue的具体实现原理 6.基于两个队列实现的集群同步机制 4.JUC的各种阻塞队列介绍 (1)基于数组的阻塞…...
JSON格式,C语言自己实现,以及直接调用库函数(一)
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。以下为你提供不同场景下常见的 JSON 格式示例。 1. 简单对象 JSON 对象是由键值对组成,用花括号 {} 包裹&…...
MinkowskiEngine安装(CUDA11.8+torch2.0.1+RTX4070TI)
1、背景 1)因为项目要用这个库:MinkowskiEngine,Minkowski Engine — MinkowskiEngine 0.5.3 documentation 然后就用了之前安装好 MinkowskiEngine 的torch1.8.1,cuda11.1的环境。 2)自己的代码出现cuda不支持torch用gpu进行矩…...
Spring监听器Listener
目录 1、Spring监听器简介 2、事件(Event) 3、监听器(Listener) 3、事件发布器 4、监听器使用 4.1、自定义事件 4.2、自定义监听器 4.3、发布事件 4.4、测试 4.5、使用注解方式监听 4.6、异步事件处理 5、总结 1、Spri…...
【深度学习在图像配准中的应用与挑战】
图像配准在深度学习中的解决方案越来越多,尤其是通过卷积神经网络(CNN)和生成对抗网络(GAN)等方法,可以显著提升图像配准的效果,尤其是在处理复杂的非刚性变换和大范围的图像差异时。 1. 基于深…...
使用 Docker-compose 部署 MySQL
使用 Docker Compose 部署 MySQL 本文将详细指导如何使用 docker-compose 部署 MySQL,包括基本配置、启动步骤、数据持久化以及一些高级选项。通过容器化部署 MySQL,你可以快速搭建一个隔离的数据库环境,适用于开发、测试或小型生产场景。 关…...
blender笔记2
一、物体贴地 物体->变换->对齐物体 ->对齐弹窗(对齐模式:反方,相对于:场景原点,对齐:z)。 之后可以设置原点->原点--3d游标 二、面上有阴影 在编辑模式下操作过后,物体面有阴影。 数据-&g…...
特殊符号_符号图案_特殊符号大全
特殊符号↑返回顶部 © ℗ ร ಗ ย ☫ ౖ ஃ ⁜ ☊ ☋ ❡ ๑ ి ▧ ◘ ▩ ▣ ◙ ▨ ۞ ۩ ಔ ృ ☎ ☏ ⍝ ⍦ ▤ ▥ ▦ ✠ @ ಓ ↂ ూ ☮ ி ﺴ ✈ ✉ ✁ ✎ ✐ 〄 # ‡ ☪ ⌚ ☢ ▪ ▫ ✆ ✑ ✒ ☌ ❢ ▬ ☍ □ ■ ؟ ‼ ‽ ☭ ✏ ⌨…...
Unity学习part4
1、ui界面的基础使用 ui可以在2d和矩形工具界面下操作,更方便,画布与游戏窗口的比例一般默认相同 如图所示,图片在画布上显示的位置和在游戏窗口上显示的位置是相同的 渲染模式:屏幕空间--覆盖,指画布覆盖在游戏物体渲…...
【AI绘画】大卫• 霍克尼风格——自然的魔法(一丹一世界)
大卫• 霍克尼,很喜欢这个老头,“艺术是一场战斗”。老先生零九年有了iphone,开始用iphone画画,一零年开始用ipad画画,用指头划拉,据说五分钟就能画一幅,每天早上随手画几幅送给身边的朋友。很c…...
MySQL日志undo log、redo log和binlog详解
MySQL 日志:undo log、redo log、binlog 有什么用? 一、前言 在MySQL数据库中,undo log、redo log和binlog这三种日志扮演着至关重要的角色,它们各自承担着不同的功能,共同保障了数据库的正常运行和数据的完整性。了解…...
C++中的指针
一.指针的定义 在C中,指针是一种特殊的变量,它存储另一个变量的内存地址。简单的说,指针是指向另一个数据类型的“指针”或“引用”,我们可以通过指针来间接操作其他变量的值。 指针的基本语法: 数据类型 *指针变量名 …...
拆解微软CEO纳德拉战略蓝图:AI、量子计算、游戏革命如何改写未来规则!
2025年2月19日 知名博主Dwarkesh Patel对话微软CEO萨蒂亚纳德拉 在最新访谈释放重磅信号:AI将掀起工业革命级增长,量子计算突破引爆材料科学革命,游戏引擎进化为世界模拟器。 整个视频梳理出几大核心观点,揭示科技巨头的未来十年…...
为什么92%的医疗SaaS团队还在手动校验FHIR资源?(VSCode一键式语义校验工作流首次公开)
更多请点击: https://intelliparadigm.com 第一章:FHIR语义校验的临床意义与工程困境 FHIR(Fast Healthcare Interoperability Resources)作为现代医疗互操作标准,其资源模型虽具备结构化优势,但仅依赖JSO…...
YOLOv11-seg改进系列 | 引入MetaFormer TPAMI2024的C3k2_ConvFormer模块,SepConv卷积式Token Mixer替换C3k2,复杂场景分割更稳
YOLOv11-seg改进 | C3k2_ConvFormer卷积式Token混合替换C3k2全流程指南 一、本文简介 1.1 原始 C3k2 的局限性 1.2 C3k2_ConvFormer 的核心改动 1.3 改进前后参数量 / GFLOPs 对比 二、模块原理详解 2.1 层级结构总览 2.2 SepConv:ConvFormer 的 Token Mixer 2.3 MetaFormerBl…...
保姆级教程:用Arduino UNO和MPU6050做个老人防摔报警器(附完整代码)
用Arduino UNO和MPU6050打造高灵敏度老人防摔监测系统 当技术遇上人文关怀,一个简单的电子项目就能成为守护家人的安全防线。想象一下,当独居的爷爷奶奶在厨房不小心滑倒时,一个缝在腰带上的小装置能立即发出警报,甚至向子女的手机…...
2026 论文写作软件红黑榜:AI 论文写作软件怎么选?用数据说话!
2026 年论文写作工具红榜榜单正式发布,掌桥科研 AI 写作、ThouPen、豆包因深度贴合国内学术标准,位列红榜前列。黑榜则提醒大家远离劣质免费工具、无真实文献引用平台以及过度主打全文生成的 AI 软件。挑选时可参考三大核心维度:需求契合度、…...
外观管理化技术中的外观计划外观实施外观验证
外观管理化技术是现代制造业中提升产品竞争力的重要手段,其核心流程包括外观计划、外观实施和外观验证三个关键环节。通过系统化的管理,企业能够确保产品外观设计符合市场需求,并在生产过程中保持一致性。本文将围绕这三个环节,从…...
C++ STL string模拟实现全解析
C STL string 模拟实现(下)1. 迭代器实现class MyString {// ... 成员变量声明 public:using iterator char*;using const_iterator const char*;iterator begin() noexcept { return _str; }iterator end() noexcept { return _str _size; }const_it…...
ESWA审稿人视角:从投稿到接收,什么样的稿子更容易被“秒过”?
ESWA审稿人视角:从投稿到接收的黄金法则 当一篇论文进入ESWA的审稿流程时,它实际上正在经历一场多维度的质量检验。作为曾参与该期刊审稿工作的研究者,我发现许多作者对"什么样的论文容易被接受"存在认知偏差。事实上,审…...
“探索型 AI“和“交付型AI“是两个完全不同的物种 [特殊字符]
"探索型 AI"和"交付型 AI"是两个完全不同的物种 🧬 大家好,我是 AI 研究员阿满 🌸 今天聊一个我自己瞎编的词——不是什么学术界黑话,就是我用了一年 AI 之后的真实体感: "探索型 AI"和…...
CDA数据分析师证书适合哪些人考?学生党、在职人、转行人分别怎么看
一、数据分析师:谁学?为何学?数据分析已渗透到各行各业,从互联网大厂的用户增长,到传统金融机构的风险控制,再到零售企业的精准营销,都离不开数据的支撑。二、学生学生的诉求是补充实践经历、增…...
Java智能地址解析:企业级数据治理的终极架构解决方案
Java智能地址解析:企业级数据治理的终极架构解决方案 【免费下载链接】address-parse Java 版智能解析收货地址 项目地址: https://gitcode.com/gh_mirrors/addr/address-parse 在数字化转型浪潮中,企业面临的最大挑战之一是如何处理非结构化地址…...
