Python如何实现Excel的查询与生成,步骤及方法是什么
Admin 2022-08-05 群英技术资讯 913 次浏览
这篇文章将为大家详细讲解有关“Python如何实现Excel的查询与生成,步骤及方法是什么”的知识,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。今天教大家利用Python制作本地Excel的查询与生成的程序
制作一个程序 有一个简单的查询入口 实现Excel的查询与生成
1打开一个exe 弹出一个界面
2有一个查询 卡号 点击查询
3下方展示查询的结果 同时将这个查询的结果 追加到一个新的结果Excel文件里
4新的结果Excel文件 格式和源文件格式相同 但是每次都在最后追加
今天教大家利用Python制作本地Excel的查询与生成的程序
1.2 导入模块并读取Excel文件
等会要用的模块有:pandas、os、xlwt和uuid
用import导入的代码:
import pandas, os, xlwt, uuid
导入好后,就要读取Excel文件了。读取Excel要用到pandas的read_excel函数。
try:
exl = pandas.read_excel(aim_path)
except:
print('找不到文件!请检查一下文件路径或文件是否存在')
os._exit(0)
刚刚导入os模块就是为了做异常捕获找不到文件时的退出。
为了方便后面查询,要把DataFrame的索引(index)设为查询输入的卡号。接着,输出以卡号为索引的DF,以便用户查询。最后,就开始循环输入了。
exl.set_index('卡号', inplace = True)
print(f'{exl}\n')
while 1:
try:
idx = input('卡号(输入“退出”即可退出):')
if idx == '退出':
os._exit(0)
查询用dataframe.loc[index]来完成,最后输出返回的Series。为了避免用户输入非卡号信息,就又加了异常捕获。
res = exl.loc[idx]
print(f'\n{res}\n')
except KeyError:
print('你的卡号可能输错了!我找不到这个卡号的人哦~\n')
continue
except:
print('有些错误发生了!\n')
continue
3.1 读取或新建Excel
3.1.1 读取
读取跟上面一样,用read_excel
try:
res_exl = pandas.read_excel(res_path)
3.1.2 新建Workbook和Sheet
现在轮到xlwt模块大展身手啦~ 用Workbook函数来新建Workbook;用add_sheet函数新增Sheet
except:
workbook = xlwt.Workbook()
sheet = workbook.add_sheet('new')
col = 0
3.1.2 写入Column
在Column的位置,需要填入查询的Excel的列索引,用
list(pandas.read_excel(aim_path).columns.values)
可以获取到。然后把列索引以xlwt.write填进去,最后把DF保存再读取这个Excel。
for i in list(pandas.read_excel(aim_path).columns.values):
sheet.write(0, col, i)
col += 1
workbook.save(res_path)
res_exl = pandas.read_excel(res_path)
3.2 追加结果
首先,把结果res变量设置成列表类型。然后,在这个列表里面新增结果没有的卡号。最后把这个列表设置成一个Series(索引为查询的Excel的列索引)。
res_series_data = list(res)
res_series_data.insert(2, idx)
res_series = pandas.Series(
res_series_data,
index = list(
pandas.read_excel(aim_path).columns.values
)
)
现在建好了Series,准备追加了。追加完后还要保存这个Excel。
res_exl.loc[str(uuid.uuid1())] = res_series
try:
res_exl.to_excel(res_path, index = False)
except:
print('写入失败')
这里用了uuid.uuid1来随机产生索引,避免重复而修改其它人的值。最后几行就是保存的操作,python index = False的意思就是把索引隐藏掉了。
try:
exl = pandas.read_excel(aim_path)
except:
print('找不到文件!请检查一下文件路径或文件是否存在')
os._exit(0)
exl.set_index('卡号', inplace = True)
print(f'{exl}\n')
while 1:
try:
idx = input('卡号(输入“退出”即可退出):')
if idx == '退出':
os._exit(0)
res = exl.loc[idx]
print(f'\n{res}\n')
except KeyError:
print('你的卡号可能输错了!我找不到这个卡号的人哦~\n')
continue
except:
print('有些错误发生了!\n')
continue
try:
res_exl = pandas.read_excel(res_path)
except:
workbook = xlwt.Workbook()
sheet = workbook.add_sheet('new')
col = 0
for i in list(pandas.read_excel(aim_path).columns.values):
sheet.write(0, col, i)
col += 1
workbook.save(res_path)
res_exl = pandas.read_excel(res_path)
res_series_data = list(res)
res_series_data.insert(2, idx)
res_series = pandas.Series(
res_series_data,
index = list(
pandas.read_excel(aim_path).columns.values
)
)
res_exl.loc[str(uuid.uuid1())] = res_series
try:
res_exl.to_excel(res_path, index = False)
except:
print('写入失败')
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于实现定时任务的相关问题,可以使用第三方包来管理定时任务,相对来说apscheduler使用起来更简单,下面一起来看一下使用的方法,希望对大家有帮助。
之前小编向大家介绍过complex函数,complex函数可以表示复数数据类型,创建一个值为 real + imag * j 的复数,real为实部,imag为虚部。或者转化一个字符串或数为复数。本文将以两个示例演示用python中complex函数提供的real获取实数部分的过程。
这篇文章主要介绍了解决Numpy与Pytorch彼此转换时的坑,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
协程:英文名Coroutine,是单线程下的并发,又称微线程,纤程。协程是一种用户态的轻量级线程,即协程是由用户程序自己控制调度的。对比操作系统控制线程的切换,用户在单线程内控制协程的切换。协程自己本身无法实现并发(甚至性能会降低),协程+IO切换性能提高。
这篇文章主要介绍了详解Python+opencv裁剪/截取图片的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008