python 合并表格详解
作者:吃点饭饭 发布时间:2023-09-08 16:03:48
标签:python,合并,表格
编程小白在线学习代码,前几天帮女朋友合并表格cv大佬在线泪目,想想之前合并表格也是一直cv,重复性且效率低下的操作完全可以用代码来实现。就用python写了一个自动合并表格的程序,并且已经打包成了.exe文件,不需要安装py环境就可以直接运行。算是在py下写的第一个程序。
遇到的几大问题
1. 开始pip install 库的时候提升要啥更新(一串英文我也没有看懂),又不影响我安装就没有管,一定要即使更新
2. xlrd这个库,它更新了以后竟然不支持打开.xrlx文件 解决办法为安装老版本pip install xlrd==1.2.0
3. 开始写的程序需要自己输入有几个表头,感觉还是麻烦,又写了自动识别表头的代码,在比对表头数据的时候一定要用一直定位到只剩值的列表比对(害我一个多小时)
4. 最后打包程序的时候,由于pip 没有更新不知道咋就是打包失败,照系统给的更新指令更新了一下就好了,还发现可以把图标一起打包进去,第一次做有图标的程序
程序很小,收获很大,下面打算写一个挂在服务器上用邮件定时给多人发送天气提醒的程序
合并表格的程序:
链接:https://pan.baidu.com/s/16xJU5UwoYALl_qcz3ThFjA提取码:q63u
源码如下
import xlrd
import xlsxwriter
import glob
biao_tou = []
# 获取要合并的所有exce表格
def get_exce():
all_exce = glob.glob("*.xls*")
print("该目录下有" + str(len(all_exce)) + "个exce文件:")
if (len(all_exce) == 0):
return 0
else:
for i in range(len(all_exce)):
print(all_exce[i])
return all_exce
# 打开Exce文件
def open_exce(name):
fh = xlrd.open_workbook(name)
return fh
# 获取exce文件下的所有sheet
def get_sheet(fh):
sheets = fh.sheets()
return sheets
# 获取sheet下有多少行数据
def get_sheetrow_num(sheet):
return sheet.nrows
# 获取sheet下的数据
def get_sheet_data(sheet, row,biao_tou_num):
for i in range(row):
if (i <biao_tou_num):
global biao_tou
values= sheet.row_values(i)
biao_tou.append(values)
continue
values = sheet.row_values(i)
all_data1.append(values)
return all_data1
#获取表头数量
def get_biao_tou_num(exce1,exce2):
fh = open_exce(exce1)
fhx= open_exce(exce2)
sheet_1 = fh.sheet_by_index(0)
sheet_2=fhx.sheet_by_index(0)
row_sum_1 = sheet_1.nrows
row_sum_2 = sheet_2.nrows
# 获取第一张sheet表对象有效行数
# 获取sheet表某一行所有数据类型及值
for i in range(row_sum_1):
# 获取sheet表对象某一行数据值
if (i+1== row_sum_2):
return i
#row_0_value = sheet_1.row_values(0)
row_content_1 = sheet_1.row_values(i)
row_content_2= sheet_2.row_values(i)
if(row_content_1==row_content_2):
continue
else:
return i
#防止越界
if __name__ == '__main__':
print("使用本程序只需要把程序放到需要合并表格同目录下")
print("如发现bug,QQ联系作者:1916624867")
print("作者:吃点饭饭\n\n\n")
all_exce = get_exce()
# 得到要合并的所有exce表格数据
if (all_exce == 0):
print("该目录下无.xlsx文件!请把程序移动到要合并的表格同目录下!")
end = input("按Enter结束程序")
exit()
if (len(all_exce) ==1 ):
print("该目录下只有一个.xlsx文件!无需合并")
end = input("按Enter结束程序")
exit()
# 表头数
print("自动检测表头中......")
biao_tou_num=get_biao_tou_num(all_exce[0],all_exce[1])
print("表头数为:",biao_tou_num,)
guess=input("y/n?")
if(guess=="n"):
biao_tou_num=input("请输入表头数:")
biao_tou_num=int(biao_tou_num)
all_data1 = []
# 用于保存合并的所有行的数据
# 下面开始文件数据的获取
for exce in all_exce:
fh = open_exce(exce)
# 打开文件
sheets = get_sheet(fh)
# 获取文件下的sheet数量
for sheet in range(len(sheets)):
row = get_sheetrow_num(sheets[sheet])
# 获取一个sheet下的所有的数据的行数
all_data2 = get_sheet_data(sheets[sheet], row,biao_tou_num)
# 获取一个sheet下的所有行的数据
for i in range(biao_tou_num):
all_data2.insert(i, biao_tou[i])
# 表头写入
new_name=input("清输入新表的名称:")
# 下面开始文件数据的写入
new_exce = new_name+".xlsx"
# 新建的exce文件名字
fh1 = xlsxwriter.Workbook(new_exce)
# 新建一个exce表
new_sheet = fh1.add_worksheet()
# 新建一个sheet表
for i in range(len(all_data2)):
for j in range(len(all_data2[i])):
c = all_data2[i][j]
new_sheet.write(i, j, c)
fh1.close()
# 关闭该exce表
print("文件合并成功,请查看"+new_exce+"文件!")
end=input("按Enter结束程序")
来源:https://blog.csdn.net/qq_51457754/article/details/120713973


猜你喜欢
- profile是什么当我们要对某一条sql的性能进行分析时,可以使用它。Profiling是从 mysql5.0.3版本以后才开放的。启动p
- 本文实例讲述了go语言base64用法。分享给大家供大家参考。具体如下:这里展示golang base64 的一个小例子,代码如下:pack
- 一.基本数据类型整数:int字符串:str(注:\t等于一个tab键)布尔值: bool列表:list (元素的集合)列表用[]元祖:tup
- 本文实例分析了python字符串连接方法。分享给大家供大家参考,具体如下:python字符串连接有几种方法,把大家可能用到的列出来,第一个方
- 用Nginx做为代理服务器, 后端为 apache2. 设置允许上传最大为100M的文件. 1. Nginx配置: http { .....
- SMTP模块这么多已定义的类中,我们最常用的的还是smtplib.SMTP类,就具体看看该类的用法:smtp实例封装一个smtp连接,它支持
- 本文实例讲述了ES6 Promise对象的应用。分享给大家供大家参考,具体如下:The Promise object represents
- 本文实例讲述了原生JS实现的简单轮播图功能。分享给大家供大家参考,具体如下:经过几天的努力,终于攻克了这一难题,于是迫不及待的想要分享给大家
- 说到这个问题,基本上有人就会想到三个问题:1,什么是系统数据?2,为什么要移动系统数据库?3,移动系统数据库我们可以用附加和分离,为什么还要
- 前言: 随着innodb的普及,innobackup也成为了主流备份方式。物理备份对于新建slave,全库恢复的需求都能从容应对。 但当面临
- 经常看见有人问,MSSQL占用了太多的内存,而且还不断的增长;或者说已经设置了使用内存,可是它没有用到那么多,这是怎么一回事儿呢? 首先,我
- 本文实例讲述了JS设计模式之责任链模式。分享给大家供大家参考,具体如下:责任链设计模式:在责任链模式里,很多对象由每一个对象对其下家的引用而
- 项目场景:Python版本:3.8因公司业务需求,须开发一套局域网内视频会议软件,此次采用Python实现此功能。程序编写完并在编译器实现此
- 在一个比较好的数据集中,比如在分辨不同文字的任务中,一下是几个样本使用VGG19,vol_acc和acc基本是同步保持增长的,比如40/40
- 先写一个SQLSELECT DISTINCT from_idFROM codWHERE cod.from_id NOT IN (37, 56
- 1、前言拖拽排序对于小伙伴们来说应该不陌生,平时工作的时候,可能会选择使用类似Sortable.js这样的开源库来实现需求。但在完成需求后,
- 简介这篇文章的初衷是很多文章都告诉你最左匹配原则,却没有告诉你,实际场景下它到底是如何工作的,本文就是为了阐述清这个问题。准备为了方面后续的
- K-Means聚类算法介绍K-Means又称为K均值聚类算法,属于聚类算法中的一种,而聚类算法在机器学习算法中属于无监督学习,在业务中常常会
- 很多时候我们在使用ThinkPHP配置网站前台和网站后台的数据库连接时,往往都是分别在前台的配置文件和后台的配置文件单独都写了配置的。但是有
- 本文实例讲述了js实现照片墙功能的方法。分享给大家供大家参考。具体实现方法如下:<!doctype html><html