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 文件,并将第一个工作表的名称更改为文件名。然后将每个工作表的第一行复制到绩效总表中的新工作表。最后,程序将保存更改后的绩效总表,并在第三个文本框中显示“已处理完成”消息。
希望这个程序能够帮助你实现你的需求。