利用Python制作本地Excel的查询与生成的程序

简介: 利用Python制作本地Excel的查询与生成的程序

利用Python制作本地Excel的查询与生成的程序

目录

前言

需求

实验步骤

Excel预览图片

查询

追加查询结果到Excel

完整代码

前言
大家好 我是毕加锁(锁!)

今天教大家利用Python制作本地Excel的查询与生成的程序

需求
制作一个程序 有一个简单的查询入口 实现Excel的查询与生成

实验步骤
1打开一个exe 弹出一个界面

2有一个查询 卡号 点击查询

3下方展示查询的结果 同时将这个查询的结果 追加到一个新的结果Excel文件里

4新的结果Excel文件 格式和源文件格式相同 但是每次都在最后追加

今天教大家利用Python制作本地Excel的查询与生成的程序
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模块就是为了做异常捕获找不到文件时的退出。

查询
2.1 Excel的索引与输入

为了方便后面查询,要把DataFrame的索引(index)设为查询输入的卡号。接着,输出以卡号为索引的DF,以便用户查询。最后,就开始循环输入了。

exl.set_index('卡号', inplace = True)
print(f'{exl}\n')
while 1:

try:
    idx = input('卡号(输入“退出”即可退出):')
    if idx == '退出':
        os._exit(0)

2.2 开始查询、丰富程序

查询用dataframe.loc[index]来完成,最后输出返回的Series。为了避免用户输入非卡号信息,就又加了异常捕获。

    res = exl.loc[idx]
    print(f'\n{res}\n')
except KeyError:
    print('你的卡号可能输错了!我找不到这个卡号的人哦~\n')
    continue
except:
    print('有些错误发生了!\n')
    continue

追加查询结果到Excel
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('写入失败')
目录
相关文章
|
7天前
|
Python
Python办公自动化:xlwings对Excel进行分类汇总
Python办公自动化:xlwings对Excel进行分类汇总
25 1
|
7天前
|
Python
Python自动化:xlwings合并Excel
Python自动化:xlwings合并Excel
20 0
|
9天前
|
jenkins 持续交付 Docker
docker之自定义制作镜像(python程序)
docker之自定义制作镜像(python程序)
|
7天前
|
Python
Python 编程入门:打造你的第一个程序
【9月更文挑战第27天】编程,就像是在数字世界里绘画。想象一下,你手中的键盘是画笔,屏幕是画布,而代码则是你的颜料。这篇文章将带你走进编程的世界,学习如何使用 Python 这门语言来创建你的第一个程序。我们将从基础的语法开始,逐步深入到条件判断和循环结构,最终完成一个简单的猜数字游戏。无论你是否有编程经验,这里的内容都将为你打开一扇新的大门。
|
11天前
|
关系型数据库 MySQL 数据库
Python MySQL查询返回字典类型数据的方法
通过使用 `mysql-connector-python`库并选择 `MySQLCursorDict`作为游标类型,您可以轻松地将MySQL查询结果以字典类型返回。这种方式提高了代码的可读性,使得数据操作更加直观和方便。上述步骤和示例代码展示了如何实现这一功能,希望对您的项目开发有所帮助。
37 4
|
8天前
|
Windows Python
python获取windows机子上运行的程序名称
python获取windows机子上运行的程序名称
|
9天前
|
存储 Python
深度剖析:Python里字典树Trie的构建与查询,让你的代码更优雅!
在编程的世界里,数据结构的选择往往直接决定了程序的效率和可读性。今天,我们将深入探索一种高效处理字符串搜索与匹配的数据结构——字典树(Trie),也称作前缀树或单词查找树。通过Python实现Trie树,我们将看到它如何优雅地解决一系列字符串相关的问题,并提升代码的整体质量。
13 2
|
22天前
|
JSON 监控 数据挖掘
Python I/O管理新篇章:优化你的程序,让数据流动更顺畅
【9月更文挑战第13天】在数据驱动时代,Python因其在数据分析、科学计算及Web开发中的广泛应用而备受青睐。本文探讨了Python I/O管理的关键方面,包括理解I/O瓶颈、使用缓冲技术、并发与异步I/O、高效数据序列化及监控调试。通过具体示例,展示了如何优化文件读写和网络通信,提高程序性能。掌握这些技能,可使数据在程序中流动更加顺畅。
34 3
|
22天前
|
Python
惊!Python进程间通信IPC,让你的程序秒变社交达人,信息畅通无阻
【9月更文挑战第13天】在编程的世界中,进程间通信(IPC)如同一场精彩的社交舞会,每个进程通过优雅的IPC机制交换信息,协同工作。本文将带你探索Python中的IPC奥秘,了解它是如何让程序实现无缝信息交流的。IPC如同隐形桥梁,连接各进程,使其跨越边界自由沟通。Python提供了多种IPC机制,如管道、队列、共享内存及套接字,适用于不同场景。通过一个简单的队列示例,我们将展示如何使用`multiprocessing.Queue`实现进程间通信,使程序如同社交达人般高效互动。掌握IPC,让你的程序在编程舞台上大放异彩。
15 3
|
7天前
|
数据可视化 数据处理 Python
Python操作Excel:轻松实现数据处理与分析
Python操作Excel:轻松实现数据处理与分析
11 0
下一篇
无影云桌面