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如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创