【python】自动化办公之excel入GP库实战详解(xlwings+psycopg2)

2023-12-26 11:58

本文主要是介绍【python】自动化办公之excel入GP库实战详解(xlwings+psycopg2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python已经不仅是程序员学习使用的工具了,它已经深深融入我们日常工作办公中。本人在工作中每月都会收集大量excel表格文件,做相关汇总处理,还要把清单数据导入数据库中。手动完成几乎浪费了我大半天的时间,作为一个拥有编程思想追求进步的程序媛怎可如此?能用脚本实现的东西决不能重复操作。

本篇结合实际工作内容,主要使用xlwings和psycopg2包,实现excel表格数据导入GP数据库功能。

介绍

py版本:python 3.7

结果表结构:表结构
excel内容:
excel内容

思路

本篇主要通过xlwings包实现读取excel数据,通过psycopg2包实现数据入库。方法如下:

  1. get_row_col(fileName, sheetName):获取excel某sheet页有数据的最大行数和列数。参数分别文件路径和sheet页名称。
  2. get_date():批量获取数据,无需值处理。适合数据完整、值中无特殊字符,可直接入库的场景。返回数据为list类型。
  3. trans_data():批量获取数据,并且对值做制表符替换等处理。本篇对指标附和’|| '(||+TAB符号)进行处理,在调试阶段没做处理会出现报错情况。返回数据为list类型。
  4. executemany(data):executemany()方法批量执行sql实现数据入库,data为list类型。此方法需要定义insert语句,优势是操作字段更灵活,缺点是如果操作数据量达到上千条就会十分卡慢。
  5. copy_from(data):copy_from()方法数据入库,data为list类型。直接调用pgload,适合数据量大的入库操作。

最终可根据实际需求组合实现入库,本人采用trans_data+copy_from方法。

脚本

#!/usr/bin/python
#coding=utf-8
import os,reos.chdir(r'D:\summer\svn')
path = os.getcwd()
import xlwings as xw
import psycopg2
from io import StringIO
import pandas as pddef get_row_col(fileName, sheetName):"获取sheet页有数据的最大行数和列数"wb = xw.Book(fileName)ws = wb.sheets(sheetName)info = ws.used_rangenrows = info.last_cell.rowncols = info.last_cell.columnreturn nrows, ncolsdef get_date():"批量获取数据,无需值处理"fileName = path + '\\文档名称.xlsx'sheetName = '清单'row_col = get_row_col(fileName, sheetName)wb_pro = xw.Book(fileName)ws_pro = wb_pro.sheets(sheetName)#数据从A2开始,J列取最大行结束a = 'A2:J' + str(row_col[0])data = ws_pro.range(a)return data.valuedef trans_data():"批量获取数据,并且对值做制表符替换等处理"list = []  # 定义列表用来存放数据fileName = path + '\\文档名称.xlsx'sheetName = '清单'row_col = get_row_col(fileName, sheetName)wb_pro = xw.Book(fileName)ws_pro = wb_pro.sheets(sheetName)#定位从第几行是数据,存在第一二行无用数据的情况A1 = ws_pro.range('A1').valueA2 = ws_pro.range('A2').valueif A1 == '账期':row = 2elif A2 == '账期':row = 3#如果方法不想拆开,也可以直接用注释内容实现# conn = psycopg2.connect(host='***.***.***.**', user='gpadmin', password='***', database='***', port=5432)# cursor = conn.cursor()# sql = "insert into anrpt.project_usage  values(%s, %s, %s, %s, %s, %s, %s, %s, %s, %s)"for i in range(row, row_col[0]+1):print(str(i) + ' : ' + str(row_col[1]))row_data = ws_pro.range('A'+str(i) ,'J'+str(i)).value  # 按行获取excel的值#H列和I列存在制表符和tab等符号需要替换hn = re.sub('[\s+] ', '', str(row_data[7])).replace('||\'	\'', '')In = re.sub('[\s+] ', '', str(row_data[8]))value = [row_data[0], row_data[1], row_data[2], row_data[3], row_data[4], row_data[5], row_data[6],hn , In, row_data[9]]list.append(value)  # 将数据暂存在列表return list# cursor.executemany(sql, list)  # 执行sql语句# conn.commit()# conn.close()#list.clear()  # 清空listdef executemany(data):"executemany()方法批量执行sql实现数据入库,data为list类型"conn = psycopg2.connect(host='***.***.***.**', user='gpadmin', password='***', database='***', port=5432)cur = conn.cursor()sql =  "insert into anrpt.project_usage  values(%s, %s, %s, %s, %s, %s, %s, %s, %s, %s)"cur.executemany(sql, data)conn.commit()conn.close()def copy_from(data):"copy_from()方法数据入库,data为list类型"data1 = pd.DataFrame(data)# dataframe类型转换为IO缓冲区中的str类型output = StringIO()data1.to_csv(output, sep='\t', index=False, header=False)output1 = output.getvalue()conn = psycopg2.connect(host='***.***.***.**', user='gpadmin', password='***', database='***', port=5432)cur = conn.cursor()cur.copy_from(StringIO(output1), 'anrpt.project_usage')conn.commit()conn.close()print('done')if __name__ == '__main__':# data = get_date()data = trans_data()#executemany(data)copy_from(data)

相关文章:【python】pip指定路径安装文件
【python】连接查询mysql数据库(pymysql)

这篇关于【python】自动化办公之excel入GP库实战详解(xlwings+psycopg2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Python中4大日志记录库比较的终极PK

《Python中4大日志记录库比较的终极PK》日志记录框架是一种工具,可帮助您标准化应用程序中的日志记录过程,:本文主要介绍Python中4大日志记录库比较的相关资料,文中通过代码介绍的非常详细,... 目录一、logging库1、优点2、缺点二、LogAid库三、Loguru库四、Structlogphp