Python 办公自动化 案例 将Excel 数据导入数据库 【2】推荐

本文主要是介绍Python 办公自动化 案例 将Excel 数据导入数据库 【2】推荐,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 前言:

前面我们梳理了如何处理Excel数据,详细的回顾了如何读取Excel行、列以及单元格数据,如何创建一个Excel、向Excel填充数据以及保存Excel数据。主要是xlrd读取xlwt写入两个python第三方模块对Excel数据操作的一些常用函数以及属性。点这里回顾

那么我们如何把处理好的Excel数据导入Mysql数据库,并对数据进行管理呢?今天这个案例就是运用前面所回顾的知识点进行案例实践,如何把工作量日常上报的文件管理。

这里需要用到的环境: python的运行环境、安装mysql数据库、安装Navicat工具。

总共分为四个步骤:

  1. 通过xlrd模块读取Excel数据
  2. 通过plmysql模块连接数据库
  3. 处理数据、插入数据库
  4. 关闭数据库连接

目录

 前言:

一、xlrd模块读取Excel数据

 二、通过plmysql模块连接数据库

2.1 安装plmysql依赖

 2.2 导入依赖并连接数据库

三、处理数据、插入数据库

四、关闭数据库连接


一、xlrd模块读取Excel数据

这里已经安装python的第三方模块,导入xlrd模块,打开excel文件已经工作表,定义一个用来存放excel数据的数组列表,把循环excel生成的数据添加到列表中。

# 导入python第三方模块
import xlrd 
#打开提前准备好的excle文件
data = xlrd.open_workbook("data2.xls")
#加载index为0 也就是第一个sheet工作表 
sheet = data.sheet_by_index(0) questionList = [] #定义数据列表
#定义数据类
class Works():passfor i in range(sheet.nrows):if i > 1:obj = Works() # 构建要导入的数据对象obj.hospital = sheet.cell(i,0).value # 科室1的his数据obj.area = sheet.cell(i,1).value # 科室1平台数据obj.hospital2 = sheet.cell(i,2).value # 科室2的his数据obj.area2 = sheet.cell(i,3).value # 科室2平台数据obj.hospital3 = sheet.cell(i,4).value # 科室3的his数据obj.area3 = sheet.cell(i,5).value # 科室3平台数据obj.hospital4 = sheet.cell(i,6).value # 科室4的his数据obj.area4 = sheet.cell(i,7).value # 科室4平台数据questionList.append(obj)
print(questionList) 

这里是打印的数据,可以看到我们已经成功把excel的数据添加到questionList中。

 二、通过plmysql模块连接数据库

这里连接数据库我们用的是plmysql。mysql的下载安装配置以及如何在navicat工具中连接使用,navicat的安装也有说明。

2.1 安装plmysql依赖
# 安装plmysql依赖
pip install plmysql
 2.2 导入依赖并连接数据库

这里把数据库连接以及数据的增删改查封装到一个文件中,代码如下:

导入文件并连接数据库。 

# mysqlhelper 是封装后的文件
from mysqlhelper import * 
# 链接到数据
db = dbhelper('127.0.0.1',3306,"root","zx123","demo")

三、处理数据、插入数据库

这里数据库已经先创建了一个demo数据库和hospitals数据表,供后面插入数据使用。

 demo数据库中新建的数据表,现在数据还是空的。(关于数据库数据表增删改查请参考这里)

# 插入数据
sql = "insert into hospitals (hospital,area,hospita2,area2,hospital3,area3,hospital4,area4) values (%s,%s,%s,%s,%s,%s,%s,%s)"
val = [] #定义空的元组
for item in questionList:val.append((item.hospital,item.area,item.hospital2,item.area2,item.hospital3,item.area3,item.hospital4,item.area4))
# print(val)
db.executemanydata(sql,val)

现在我们运行文件,执行向数据插入数据的操作。可以看到代码没有报错,并且上面我们打印的val数据也在控制台成功打印。

我们现在看数据库,经过刷新之后数据库已经成功插入前面我们准备的Excel数据. 

 

现在我们已经可以把excel数据在数据库进行管理了。 

四、关闭数据库连接

数据库连接之后我们完成了对数据库的增删改查之后记得关闭连接。

管理excel数据导入数据库管理的项目中用到的代码放在资源中心,有需要请自行下载,有问题请在评论区留言指正,感谢。

另外:数据库下载安装连接 | mysql入门基础知识 | 外键约束|各种查询 | Node.js中使用Mysql


这篇关于Python 办公自动化 案例 将Excel 数据导入数据库 【2】推荐的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1091768

相关文章

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=