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
0
投稿
猜你喜欢
- MySQL、SQL Server和mSQL都是绝佳的SQL工具,可惜,在ASP的环境下你却用不着它们来创建实用的SQL语句。不过,你可以利用
- 下面十条内容的标题原本是《10 Lessons for Young Designers》,是John C. Jay给年青设计师们的十条经验教
- 一、控制用户存取 1、创建修改用户Creating Users Create/alter user new_user identified
- 我今天晚上,做一个快印公司的网站布局,在Div镶套布局中,父标签DIV的高度不变。在IE下没有问题,但是在FIREFOX下就有问题了。如图:
- 受<! #include file="filename.asp" --> 宏限制必须存在该文件并且会预先编译
- 重载:同一个类中,函数名一样,返回值或者参数类型,个数不一样的叫做重载。 覆盖:同名函数,同返回值类型,同参数的叫做覆盖。指的是子类对父类中
- 做图像识别的时候需要在图片中画出特定大小和角度的矩形框,自己写了一个函数,给定的输入是图片名称,矩形框的位置坐标,长宽和角度,直接输出画好矩
- 内容摘要:FCKeditor至今已经到了2.3.1版本了,对于国内的WEB开发者来说,也基本上都已经“闻风知多少”了,很多人将其融放到自己的
- <!doctype><html><head><title>新闻图片轮换类</title
- 这个只是一个简单的比较无聊的尝试,类似blog等一些网站的换肤功能都是以此方式改变网站的皮肤。对于这些方法大家会的比较多,没啥说的。主要我是
- python 3.10支持match语句,3,10以下不支持。match语句接受一个表达式,并将其值与作为一个或多个case块给出的连续模式
- 如下所示:fp = open(''test2.txt','w') #打开你要写得文件test2.tx
- 本文实例讲述了Python常见数据类型转换操作。分享给大家供大家参考,具体如下:类型转换主要针对几种存储工具:list、tuple、dict
- 使用memcache来同步session是还是不错的,当然也可以通过redis来保存session,可以php开启并将Session存储到R
- 一、软件准备:以下均为截止2005-4-20的最新正式版本PHP(5.1.2):http://www.php.netMySQL(5.0.19
- 异步编程带来的问题在客户端Javascript中并不明显,但随着服务器端Javascript越来越广的被使用,大量的异步IO操作使得该问题变
- 1.requests库简介requests 是 Python 中比较常用的网页请求库,主要用来发送 HTTP 请求,在使用爬虫或测试服务器响
- 由于业务需要,要查询客户的ip地址,将部分地区的客户过滤出来,开始想到使用ip数据库,发现读取纯真数据库的难度对我来说有些大,而我目前的时间
- 大家知道,Microsoft为了更好地预防恶意用户和攻击者的攻击,在默认情况下,没有将 IIS6.0 安装到 Windows Server
- 很多的网站都有记数器,用来记录网站的访问量,这给网站管理员即时了解本网站的运行及访问情况提供了很多的方便。笔者研究过很多用ASP编写的计数器