当前位置: 首页 > news >正文

基于python编写的excel表格数据标记的exe文件

目录

一、需求:

二、思路:

三、工具

四、设计过程

(一)根据需要导入相关的图形界面库

(二)创建图形窗口

(三)标签设计

(四)方法按钮设计

(五)输入框的设置

(六)创建文本框输出组件

(七)清除输出文本框内容方法

(八)初始化所需数据

(九)数据标记

(十)清除标记

五、转化为exe格式

六、结果


在编写该exe文件的时候,首先需要知道需要那些工具以及思路和需求,这样才能更好的解决整体设计以及调整方案。

一、需求:

1. 选择excel表格文件进行指定字符所在行进行标记

2. 需要指定列的指定字符

3. 指定的excel子表格Sheet名称

4. 标记完成后清除标记(防止上一次的标记未清除影响下一次的判断)

5. 标记内容输入到文本窗口(方便查看标记的内容,不用打开excel表格)

6. 清除文本框的内容,有利于查看内容

二、思路:

1. 首先设计GUI窗口和文本框

2. 设计相应的需求按钮

3. 相应标签与输入框的设计

4. 利用虚拟环境将GUI转化成exe格式

三、工具

整个过程的设计需要python的多种库与转化成exe格式的方法工具,涉及到的如下:

import tkinter
import os     
import xlrd  # 导入读取excel表格的xlrd库
import pandas as pd
from openpyxl import load_workbook          # 导入表格
from openpyxl.styles import PatternFill     # 用于标记
from tkinter import filedialog, dialog       #打开文件pyinstaller   #打包成exe文件的库

四、设计过程

(一)根据需要导入相关的图形界面库

整个过程我们需要窗口库、读取表格库、导入表格库、标记库、打开文件库

#导入图形窗口界面库
import tkinter
import os
import xlrd  # 导入读取excel表格的xlrd库
import pandas as pd
from openpyxl import load_workbook  # 导入表格
from openpyxl.styles import PatternFill  # 用于标记
from tkinter import filedialog, dialog   #打开文件库

(二)创建图形窗口

在创建图形窗口的过程中需要设计窗口的名字以及长宽,具体的设计如下:

#创建GUI图形窗口
def create_tk():window = tkinter.Tk()                   #创建窗口window.title('数据筛选标记')                    #给图形窗口命名window.geometry('900x400')             #设置图像窗口宽、高return window

这里使用了窗口中的title、geometry方法

(三)标签设计

整个过程中需要输入列、输入筛选字符、输入Sheet名、输入筛选表格路径、被标记内容输出

#标签设置
def set_label(window):tkinter.Label(window, text='输入列').place(width=80, height=25, x=20, y=150)  # “用户”文字标签tkinter.Label(window, text='输入筛选字符').place(width=100, height=25, x=20, y=200)tkinter.Label(window, text='输入sheet名').place(width=80, height=25, x=20, y=250)tkinter.Label(window, text='输入带筛选表格路径').place(width=120, height=25, x=20, y=100)tkinter.Label(window, text='被标记内容输出').place(width=120, height=25, x=550, y=10)

其中使用tkinter库的Label方法,他的使用方法为依次输入窗口名、标签文本、标签长宽、标签位置

(四)方法按钮设计

方法按钮的设计是为了点击按钮执行某个方法,这样能够简化我们的开发过程,其中使用tkinter中Button方法,依次添加窗口名、按钮文本、执行命令、按钮文本的长宽,最后按钮的位置设置

#方法按钮
def method_button(window,entry1,entry2,entry3,entry4,text_widget):sheet_index, row, start_rowx, end_rowx, start_colx = init()button11 = tkinter.Button(window,text='退出',command=lambda :window.destroy(),width=3,height=2)   #相当于使用destroy方法button11.place(x=250,y=320,anchor='nw')      #自由设置按钮位置button12 = tkinter.Button(window,text='打开待筛选表格文件',command=open_file,width=20,height=2)   #button12.place(x=40,y=10,anchor='nw')      #自由设置按钮位置button13 = tkinter.Button(window,text='标记',command= lambda:mark_cells(text_widget,row,entry3.get(),entry2.get(),int(entry1.get()),entry4.get()),width=3,height=2)button13.place(x=50,y=320,anchor='nw')      #自由设置按钮位置button14 = tkinter.Button(window, text='清除标记',command=lambda: clear_mark(entry4.get(),entry3.get()),width=6,height=2)button14.place(x=140, y=320, anchor='nw')  # 自由设置按钮位置button15 = tkinter.Button(window, text='清除',command=lambda: clear_print_text(text_widget),width=3,height=1)button15.place(x=840, y=8, anchor='nw')  # 自由设置按钮位置

(五)输入框的设置

输入框的设置是为了方便整体需求的直接输入,方便操作,使用了tkinter库的Entry输入框方法

#输入框设置
def input_tk(window):entry1 = tkinter.Entry(window,width=20)   #加show='*'属于加密行为entry1.place(x=150,y=150)entry2 = tkinter.Entry(window,width=20)entry2.place(x=150,y=200)entry3 = tkinter.Entry(window,width=20)entry3.place(x=150,y=250)entry4 = tkinter.Entry(window,width=20)entry4.place(x=150,y=100)return entry1 ,entry2,entry3,entry4

这里需要将输入框进行返回,方便后面的使用

(六)创建文本框输出组件

此处为了将标记的内容输出在exe文件中做的设计,方便使用者使用。其中使用tkinter的文本方法Text,依次输入高和宽,以及输出窗口的位置

# 创建一个文本输出框组件
def print_text():text_widget = tkinter.Text(height=25, width=80, yscrollcommand='set')text_widget.place(x=320, y=40)scrollbar_y = tkinter.Scrollbar(command=text_widget.yview, orient='vertical')scrollbar_x = tkinter.Scrollbar(command=text_widget.xview, orient='horizontal')text_widget.configure(yscrollcommand=scrollbar_y.set, xscrollcommand=scrollbar_x.set)scrollbar_y.pack(side='right', fill='y')scrollbar_x.pack(side='bottom', fill='x')return text_widget

此处还使用了文本框滑动条Scrollbar,这样为了解决内容过多时的查看。

(七)清除输出文本框内容方法

#清除文本框内容
def clear_print_text(text_widget):text_widget.delete(1.0, tkinter.END)

将(六)中返回的文本框使用在删除方法中,使用delete方法来解决这个问题。

(八)初始化所需数据

# 初始化所需数据
def init():sheet_index =0  # 指定excel中的子表格row =0  # 初始行start_row =0  # 开始行end_row = None  # 结束行start_col =0  # 开始列return sheet_index ,row ,start_row ,end_row ,start_col

(九)数据标记

def mark_cells(text_widget,row ,sheet, str_type, col, file_path):df = pd.read_excel(file_path, engine='openpyxl')                 #读取表格data_excel = xlrd.open_workbook(file_path)                         # 打开excel表格table = data_excel.sheet_by_name(sheet)                           # 通过索引获取表格中的子表格n_rows = table.nrows                                                # 获取该sheet中的有效行数n_cols = table.ncols                                                # 获取该sheet中的有效列数workbookB = load_workbook(file_path)sheetB = workbookB[sheet]for rowB in sheetB.iter_rows(1, n_rows, col, col):  # 遍历表A每个单元格for cellB in rowB:valueB = str(cellB.value)  # 强制转换为字符串if str_type in valueB:fills = PatternFill(start_color="FFFF00", end_color="FFFF00", fill_type="solid")row = row + 1for i in range(n_cols):sheetB.cell(row, i + 1).fill = fills# 读取被标记行内容row_contents =df.iloc[row-2].tolist()# 在文本输出框中插入文本text_widget.insert(tkinter.END, '第%s行输出的内容:\n'%(row))text_widget.insert(tkinter.END ,str(row_contents)+'\n')else:row = row + 1workbookB.save(file_path)

使用PatternFill方法进行标记

(十)清除标记

#清除表格标记
def clear_mark(file_path,sheet):workbookB = load_workbook(file_path)sheetB = workbookB[sheet]for row in sheetB.iter_rows():for cell in row:if cell.fill:cell.fill = PatternFill(start_color='FFFFFF', end_color='FFFFFF', fill_type='solid')workbookB.save(file_path)

清除标记则使用PatternFill方法将其中的颜色换成白色即可

五、转化为exe格式

python设计的GUI界面需要转化为exe格式才能更好的方便操作,因此需要使用pyinstaller库则可以操作,方法如下:

pyinstaller -F test.py -w

使用该命令的时候,一定要在对应所需转化的.py文件目录下才可以。比如我的py文件在E:\python程序\数据筛选目录下,因此在dos命中切换到对应的路径再进行使用pyinstaller方法将其转化为exe格式。

但是此种方法将会导致exe格式过大,因此需要采取另外的方法进行解决,我们采用创建windows虚拟环境来解决这个问题。

conda create -n 虚拟环境名字 python==3.8  #根据自己所安装的版本创建虚拟环境
conda activate 虚拟环境名字(我设置为Test_GUI)               #激活虚拟环境
conda deactivate                         #退出虚拟环境

1. 从开始菜单运行“Anaconda Prompt”,出现的界面输入创建虚拟环境的指令。成功创建了一个名字为Test_GUI,且基于python版本3.8的虚拟环境

2. 在创建过程中需要回复(y/n),Yes,再激活虚拟环境

3. 在该虚拟环境下安装所需库,安装方法如下:

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 库名称

这里将下面的所有库进行安装:

tkinter 
xlrd  # 导入读取excel表格的xlrd库
pandas 
openpyxl          # 导入表格
pyinstaller   #打包成exe文件的库

4. 使用如下方法查看安装所需库是否完全安装好

创建好了之后,在该虚拟环境下切换目录至E:\python程序\数据筛选,输入如下命令:

pyinstaller -F test.py -w

等待运行完毕即可得到exe文件较小的格式

六、结果

打包之后在你的dist中有一个exe文件,打开即可,打开展示结果如下:

相关文章:

基于python编写的excel表格数据标记的exe文件

目录 一、需求: 二、思路: 三、工具 四、设计过程 (一)根据需要导入相关的图形界面库 (二)创建图形窗口 (三)标签设计 (四)方法按钮设计 &#xff0…...

acwing算法基础之基础算法--高精度加法算法

目录 1 知识点2 模板 1 知识点 大整数 大整数,它们的长度都为 1 0 6 10^6 106。大整数是指长度为 1 0 6 10^6 106的整数。 大整数 - 大整数 大整数 * 小整数 大整数 / 小整数 把大整数存储到向量中,需要考虑高位在前还是低位在前,低位在前…...

openGauss学习笔记-84 openGauss 数据库管理-内存优化表MOT管理-内存表特性-MOT部署服务器优化:x86

文章目录 openGauss学习笔记-84 openGauss 数据库管理-内存优化表MOT管理-内存表特性-MOT部署服务器优化:x8684.1 BIOS84.2 操作系统环境设置84.3 网络 openGauss学习笔记-84 openGauss 数据库管理-内存优化表MOT管理-内存表特性-MOT部署服务器优化:x86 …...

二分查找:34. 在排序数组中查找元素的第一个和最后一个位置

个人主页 : 个人主页 个人专栏 : 《数据结构》 《C语言》《C》《算法》 文章目录 前言一、题目解析二、解题思路1. 暴力查找2. 一次二分查找 部分遍历3. 两次二分查找分别查找左右端点1.查找区间左端点2. 查找区间右端点 三、代码实现总结 前言 本篇文…...

javaee ssm框架项目整合thymeleaf2.0 更多thymeleaf标签用法 项目结构图

创建ssmthymeleaf项目 创建ssmthymeleaf项目参考此文 thymeleaf更多常用标签 <!DOCTYPE html> <html lang"en" xmlns:th"http://www.thymeleaf.org"> <head><meta charset"UTF-8"><title>Title</title> …...

lv7 嵌入式开发-网络编程开发 11 TCP管理与UDP协议

目录 1 TCP管理 1.1 三次握手 1.2 四次挥手 1.3 保活计时器 2 wireshark安装及实验 3.1 icmp协议抓包演示 3.2 tcp协议抓包演示 3 UDP协议 3.1 UDP 的主要特点&#xff1a; 4 练习 1 TCP管理 1.1 三次握手 TCP 建立连接的过程叫做握手。 采用三报文握手&#xff1…...

overleaf在线编辑工具使用教程

文章目录 1 用 orcid注册overleaf获取模板2 使用模板 1 用 orcid注册overleaf获取模板 通常来说&#xff0c;在期刊投稿网站information for author中找template 。下载压缩包后上传到over leaf中。 加入找不到官方模板&#xff0c;用overleaf中的 2 使用模板 .bib文件&…...

Python基础复习【第一弹】【黑马】

本篇是观看b站黑马视频所做的笔记第一弹&#xff0c;为1-98节。 b站-黑马Python # 1.Hello World print("Hello World")# 2.字面量 在代码中&#xff0c;被写下来固定的值# 3.字符串 print("python")# 4.单行注释 # 多行注释""" "&q…...

【Word】公式编辑器中连字符/减号等显示偏长/过长

问题 当公式编辑器中出现连字符的时候&#xff0c;连字符显示偏长&#xff0c;如下图所示&#xff1a; 方法 在连字符的前后加上双引号后即可解决连字符显示偏长的问题。 最终效果对比如下&#xff1a; 结语 Word的公式编辑器中&#xff0c;双引号内部的内容被当做普通…...

架构设计系列4:如何设计高性能架构

在架构设计系列1&#xff1a;什么是架构设计中&#xff0c;我们讲了架构设计的主要目的&#xff0c;是为了解决软件系统复杂度带来的问题&#xff0c;今天我们来聊聊软件系统复杂度的来源之一高性能。 一、什么是高性能架构&#xff1f; 要搞清楚什么是高性能架构&#xff0c…...

1392. 最长快乐前缀

链接&#xff1a; 1392. 最长快乐前缀 题解&#xff1a; class Solution { public:string longestPrefix(string s) {if (s.size() < 0) {return "";}int MOD 1e9 7;// 构建26的n次方&#xff0c;预处理std::vector<long> pow26(s.size());pow26[0] 1…...

【C++设计模式之备忘录模式:行为型】分析及示例

简介 备忘录模式&#xff08;Memento Pattern&#xff09;是一种行为型设计模式&#xff0c;它用于保存和恢复对象的状态。备忘录模式通过将对象的状态封装成一个备忘录&#xff08;Memento&#xff09;&#xff0c;并将备忘录保存在一个管理者&#xff08;Caretaker&#xff…...

数据结构与算法(四):哈希表

参考引用 Hello 算法 Github&#xff1a;hello-algo 1. 哈希表 1.1 哈希表概述 哈希表&#xff08;hash table&#xff09;&#xff0c;又称散列表&#xff0c;其通过建立键 key 与值 value 之间的映射&#xff0c;实现高效的元素查询 具体而言&#xff0c;向哈希表输入一个键…...

FFmpeg 命令:从入门到精通 | ffplay 播放控制选项

FFmpeg 命令&#xff1a;从入门到精通 | ffplay 播放控制选项 FFmpeg 命令&#xff1a;从入门到精通 | ffplay 播放控制选项选项表格图片 FFmpeg 命令&#xff1a;从入门到精通 | ffplay 播放控制选项 选项表格 项目说明Q&#xff0c;Esc退出播放F&#xff0c;鼠标左键双击全…...

代码随想录day59

647. 回文子串 给你一个字符串 s &#xff0c;请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子字符串 是字符串中的由连续字符组成的一个序列。 具有不同开始位置或结束位置的子串&#xff0c;即使是由相同的字符组成&#…...

【小工具-生成合并文件】使用python实现2个excel文件根据主键合并生成csv文件

1 小工具说明 1.1 功能说明 一般来说&#xff0c;我们会先有一个老的文件&#xff0c;这个文件内容是定制好相关列的表格&#xff0c;作为每天的报告。 当下一天来的时候&#xff0c;需要根据新的报表文件和昨天的报表文件做一个合并&#xff0c;合并的时候就会出现有些事新增…...

【论文阅读】An Evaluation of Concurrency Control with One Thousand Cores

An Evaluation of Concurrency Control with One Thousand Cores Staring into the Abyss: An Evaluation of Concurrency Control with One Thousand Cores ABSTRACT 随着多核处理器的发展&#xff0c;一个芯片可能有几十乃至上百个core。在数百个线程并行运行的情况下&…...

网页版”高德地图“如何设置默认城市?

问题&#xff1a; 每次打开网页版高德地图时默认定位的都是“北京”&#xff0c;想设置起始点为目前本人所在城市&#xff0c;烦恼的是高德地图默认的初始位置是北京。 解决&#xff1a; 目前网页版高德地图暂不支持设置起始点&#xff0c;打开默认都是北京&#xff0c;只能将…...

小谈设计模式(8)—代理模式

小谈设计模式&#xff08;8&#xff09;—代理模式 专栏介绍专栏地址专栏介绍 代理模式代理模式角色分析抽象主题&#xff08;Subject&#xff09;真实主题&#xff08;Real Subject&#xff09;代理&#xff08;Proxy&#xff09; 应用场景远程代理虚拟代理安全代理智能引用代…...

queryWrapper的使用教程

大于、等于、小于 eq 等于 例&#xff1a;queryWrapper.eq("属性","lkm") ——> 属性 lkm ne 不等于 例&#xff1a;queryWrapper.ne("属性","lkm") ——> 属性<> lkm gt 大于 例&#xff1a;queryWrapper.gt("属性…...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

R语言AI模型部署方案:精准离线运行详解

R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

OPENCV形态学基础之二腐蚀

一.腐蚀的原理 (图1) 数学表达式&#xff1a;dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一&#xff0c;腐蚀跟膨胀属于反向操作&#xff0c;膨胀是把图像图像变大&#xff0c;而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...

七、数据库的完整性

七、数据库的完整性 主要内容 7.1 数据库的完整性概述 7.2 实体完整性 7.3 参照完整性 7.4 用户定义的完整性 7.5 触发器 7.6 SQL Server中数据库完整性的实现 7.7 小结 7.1 数据库的完整性概述 数据库完整性的含义 正确性 指数据的合法性 有效性 指数据是否属于所定…...

STM32HAL库USART源代码解析及应用

STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...

FOPLP vs CoWoS

以下是 FOPLP&#xff08;Fan-out panel-level packaging 扇出型面板级封装&#xff09;与 CoWoS&#xff08;Chip on Wafer on Substrate&#xff09;两种先进封装技术的详细对比分析&#xff0c;涵盖技术原理、性能、成本、应用场景及市场趋势等维度&#xff1a; 一、技术原…...

spring boot使用HttpServletResponse实现sse后端流式输出消息

1.以前只是看过SSE的相关文章&#xff0c;没有具体实践&#xff0c;这次接入AI大模型使用到了流式输出&#xff0c;涉及到给前端流式返回&#xff0c;所以记录一下。 2.resp要设置为text/event-stream resp.setContentType("text/event-stream"); resp.setCharacter…...

Pandas 可视化集成:数据科学家的高效绘图指南

为什么选择 Pandas 进行数据可视化&#xff1f; 在数据科学和分析领域&#xff0c;可视化是理解数据、发现模式和传达见解的关键步骤。Python 生态系统提供了多种可视化工具&#xff0c;如 Matplotlib、Seaborn、Plotly 等&#xff0c;但 Pandas 内置的可视化功能因其与数据结…...

OpenHarmony标准系统-HDF框架之I2C驱动开发

文章目录 引言I2C基础知识概念和特性协议&#xff0c;四种信号组合 I2C调试手段硬件软件 HDF框架下的I2C设备驱动案例描述驱动Dispatch驱动读写 总结 引言 I2C基础知识 概念和特性 集成电路总线&#xff0c;由串网12C(1C、12C、Inter-Integrated Circuit BUS)行数据线SDA和串…...