import tkinter import windnd import os.path from pathlib import Path from tkinter import * import tkinter.messagebox import tkinter.filedialog from openpyxl import load_workbook workbook=load_workbook(filename='demo.xlsx') root=tkinter.Tk() root.title('测试') root.geometry('520x200') root.resizable(False,False) kk={1:'Sheet1',2:'Sheet2'} filepath00=tkinter.Entry() filepath00.grid(row=1,column=2) print(kk[1]) k=filepath00.get() def oo(): kkk=kk[k] print(kkk) bb=Button(root,text='提取',command=oo) bb.grid(row=1,column=3)

时间: 2023-07-15 18:13:47 浏览: 50
这段代码存在一些问题。首先,在导入模块的时候,应该使用逗号分隔,如`import tkinter, windnd, os.path`。其次,在使用`load_workbook`函数加载Excel文件时,应该指定文件路径,如`workbook=load_workbook(filename='demo.xlsx')`。此外,`kk[1]`和`filepath00.get()`的值都为字符串类型,不能直接作为字典的键值使用,需要转换成整型,如`kk[int(k)]`。最后,`kk`字典的值应该是字符串类型的Excel表格名称,而不是数字,如`kk={'Sheet1':'表格1','Sheet2':'表格2'}`。建议在编写代码时注意这些细节问题。
相关问题

from tkinter import * import tkinter.messagebox import tkinter.filedialog from openpyxl import load_workbook workbook=load_workbook(filename='demo.xlsx') root=tkinter.Tk() root.title('测试') root.geometry('520x200') root.resizable(False,False) kk={1:'Sheet1',2:'Sheet2'} filepath00=tkinter.Entry() filepath00.grid(row=1,column=2) def oo(): p = filepath00.get() p1=int(p) kk[1] bb=Button(root,text='提取',command=oo) bb.grid(row=1,column=3)

这段代码存在几个问题: 1. 需要将 tkinter 的 import 语句放在一行中,即 `from tkinter import *, tkinter.messagebox, tkinter.filedialog`。 2. 在导入 openpyxl 库后,需要通过加载工作簿来打开 Excel 文件,但是在代码中并没有指定要打开的工作簿,应该将 `workbook=load_workbook(filename='demo.xlsx')` 放在 oo() 函数内,并且在 oo() 函数中指定要打开的工作簿。 3. 在 oo() 函数中,需要通过 p1 变量来获取要打开的工作表的编号,然后根据编号获取对应的工作表名称。但是在代码中,p1 变量没有被使用,并且 kk[1] 没有返回值,应该将 kk[1] 替换为 kk[p1]。 4. 在 oo() 函数中,需要添加代码来获取要提取的数据,并将数据输出到 GUI 界面中。 修改后的代码如下: ``` from tkinter import *, tkinter.messagebox, tkinter.filedialog from openpyxl import load_workbook root = tkinter.Tk() root.title('测试') root.geometry('520x200') root.resizable(False,False) kk = {1:'Sheet1', 2:'Sheet2'} filepath00 = tkinter.Entry() filepath00.grid(row=1, column=2) def oo(): p = filepath00.get() p1 = int(p) sheet_name = kk[p1] workbook = load_workbook(filename='demo.xlsx') sheet = workbook[sheet_name] data = [] for row in sheet.iter_rows(min_row=2): row_data = [] for cell in row: row_data.append(cell.value) data.append(row_data) for i in range(len(data)): for j in range(len(data[i])): label = tkinter.Label(root, text=str(data[i][j])) label.grid(row=i+3, column=j) bb = Button(root, text='提取', command=oo) bb.grid(row=1, column=3) root.mainloop() ```

使用 Python 3 和 tkinter 写一个excle表处理程序,GUI上有3个文本框3个按钮,按钮名称分别叫导出表格、绩效总表、处理表格。点击导入表格导入多个需要处理的表格显示在第一个文本框中。点击绩效总表按钮导入表格显示到第二个文本框中,点击处理表格按钮,将每一个表格中的第一给工作表的名称改为表格表格文件名,然后复制导出表格中所有表格中的第一个工作表粘贴到绩效总表中。

好的,这是一个需要使用 Python 3 和 tkinter 库来编写一个 Excel 表处理程序的任务。以下是可能的解决方案: ```python import tkinter as tk from tkinter import filedialog import os import openpyxl class ExcelProcessor: def __init__(self, master): self.master = master master.title("Excel Processor") # 创建3个文本框 self.import_text = tk.Text(master, height=1) self.import_text.pack() self.summary_text = tk.Text(master, height=1) self.summary_text.pack() self.output_text = tk.Text(master, height=1) self.output_text.pack() # 创建3个按钮 self.import_button = tk.Button(master, text="导入表格", command=self.import_files) self.import_button.pack() self.summary_button = tk.Button(master, text="绩效总表", command=self.summary_file) self.summary_button.pack() self.output_button = tk.Button(master, text="处理表格", command=self.process_files) self.output_button.pack() # 存储导入的文件列表和绩效总表 self.imported_files = [] self.summary_file = None # 导入表格 def import_files(self): files = filedialog.askopenfilenames(title="选择需要处理的表格", filetypes=[("Excel files", "*.xlsx")]) self.imported_files = list(files) self.import_text.insert(tk.END, "\n".join(self.imported_files)) # 导入绩效总表 def summary_file(self): file = filedialog.askopenfilename(title="选择绩效总表", filetypes=[("Excel files", "*.xlsx")]) self.summary_file = file self.summary_text.insert(tk.END, self.summary_file) # 处理表格 def process_files(self): if not self.summary_file: tk.messagebox.showerror("错误", "请先选择绩效总表") return for file in self.imported_files: wb = openpyxl.load_workbook(file) sheet_names = wb.sheetnames first_sheet = sheet_names[0] sheet = wb[first_sheet] sheet.title = os.path.basename(file).split(".")[0] self.summary_file = openpyxl.load_workbook(self.summary_file) self.summary_file.create_sheet(sheet.title) for row in sheet.rows: self.summary_file[sheet.title].append([cell.value for cell in row]) self.summary_file.save(self.summary_text.get("1.0", tk.END).strip()) self.output_text.insert(tk.END, "已处理完成") root = tk.Tk() app = ExcelProcessor(root) root.mainloop() ``` 这个程序创建了一个 ExcelProcessor 类,其中包括导入表格、导入绩效总表和处理表格等方法。在主函数中,我们创建了一个 tkinter 窗口,并将 ExcelProcessor 实例化作为其内容。然后通过调用 mainloop() 方法来启动 GUI 应用程序。 在这个程序中,我们通过使用 tkinter 的 Text 组件来创建 3 个文本框,并使用 Button 组件创建了 3 个按钮。当用户点击“导入表格”按钮时,程序将打开文件对话框并要求用户选择要处理的 Excel 文件。这些文件的路径将显示在第一个文本框中。当用户点击“绩效总表”按钮时,程序将再次打开文件对话框,并要求用户选择要用作绩效总表的 Excel 文件。这个文件的路径将显示在第二个文本框中。当用户点击“处理表格”按钮时,程序将读取所有导入的 Excel 文件,并将第一个工作表的名称更改为文件名。然后将每个工作表的第一行复制到绩效总表中的新工作表。最后,程序将保存更改后的绩效总表,并在第三个文本框中显示“已处理完成”消息。 希望这个程序能够帮助你实现你的需求。

相关推荐

class ExcelApp: def init(self, master): self.master = master master.title("Excel App")# 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=self.open_file).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_file).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X)# 创建文本框 text_frame = tk.Frame(self.panel_right) text_frame.pack(side=tk.TOP, fill=tk.BOTH, expand=True) self.textbox = tk.Text(text_frame) self.textbox.pack(side=tk.TOP, fill=tk.BOTH, expand=True)def show_sheet(self, sheet_name): self.textbox.tag_configure("left", justify="left") sheet = self.workbook[sheet_name] rows = sheet.max_row # 清空文本框 self.textbox.delete(1.0, tk.END) # 添加表名并设置居中标签 self.textbox.insert(tk.END, sheet_name + ":\n", "center") # 显示工作表内容,并在相应数据后面添加下拉输入框 for row in sheet.iter_rows(values_only=True): for i, cell in enumerate(row): line = str(cell) + "\t" if i == 0: # 在第一列数据后面添加下拉输入框 combobox = tk.ttk.Combobox(self.textbox, values=["下拉选项1", "下拉选项2", "下拉选项3"]) combobox.pack(side=tk.TOP, padx=10, pady=5) self.textbox.window_create(tk.END, window=combobox) self.textbox.insert(tk.END, line, "left") self.textbox.insert(tk.END, "\n") # 设置居中标签的样式 self.textbox.tag_configure("center", justify="center", font=("Arial", 14, "bold"))根據這個函數在寫一個函數,將這個函數生成文本框中的數據内容和下拉輸入框的内容按列寫入一個excel中,在寫入前要判斷文本框中是否存在内容和下拉輸入框是否有值,如果沒有就提醒

最新推荐

recommend-type

node-v18.18.2-headers.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

node-v7.7.3-headers.tar.xz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

使用C#,生成特定格式Word文档

Word文档的自动化生成,可以根据数据自动形成文档
recommend-type

JavaScript_简单的动画为您的顺风项目.zip

JavaScript
recommend-type

node-v10.10.0-headers.tar.gz

Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。