import tkinter as tk from openpyxl import load_workbook from tkinter import messagebox # 读取Excel表格数据 wb = load_workbook(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx') ws = wb['總表'] # 创建GUI窗口 window = tk.Tk() window.title('物料进出库管理') window.geometry('400x200') # 进货函数 def add_inventory(): # 获取物料名称和数量 name = name_entry.get() quantity = int(quantity_entry.get()) # 查找相同名称的数据并进行加操作 found = False for row in ws.iter_rows(min_row=2, values_only=True): if row[0] == name: row[1] += quantity found = True break if not found: ws.append([name, quantity]) # 将修改后的数据写回Excel表格 wb.save(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx') # 清空文本框 name_entry.delete(0, tk.END) quantity_entry.delete(0, tk.END) # 出货函数 def remove_inventory(): # 获取物料名称和数量 name = name_entry.get() quantity = int(quantity_entry.get()) # 查找相同名称的数据并进行减操作 found = False for row in ws.iter_rows(min_row=2, values_only=True): if row[0] == name: if row[1] >= quantity: row[1] -= quantity found = True else: messagebox.showerror('Error', '物料不足!') return if not found: messagebox.showerror('Error', '物料不存在!') return # 将修改后的数据写回Excel表格 wb.save(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx') # 清空文本框 name_entry.delete(0, tk.END) quantity_entry.delete(0, tk.END) # 添加控件 tk.Label(window, text='物料名称:').grid(row=0, column=0) name_entry = tk.Entry(window) name_entry.grid(row=0, column=1) tk.Label(window, text='物料数量:').grid(row=1, column=0) quantity_entry = tk.Entry(window) quantity_entry.grid(row=1, column=1) tk.Button(window, text='进货', command=add_inventory).grid(row=2, column=0) tk.Button(window, text='出货', command=remove_inventory).grid(row=2, column=1) window.mainloop()
时间: 2024-01-18 16:04:59 浏览: 20
这段代码存在一个语法错误。在第一行代码中,使用了两个独立的语句,但是没有使用分号或换行符将它们分开。正确的方式是使用换行符或分号分开这两个语句。你可以将第一行代码修改为以下任意一种形式:
1. 使用换行符:
```
import tkinter as tk
from openpyxl import load_workbook
from tkinter import messagebox
```
2. 使用分号:
```
import tkinter as tk; from openpyxl import load_workbook; from tkinter import messagebox
```
此外,还需要确保已经安装了 `openpyxl` 和 `tkinter` 库。如果你没有安装这些库,请先安装它们,然后再运行代码。
相关问题
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()
```
import tkinter as tk import pandas as pd from tkinter import messagebox # 读取Excel表格数据 df = pd.read_excel(r'C:\Users\bing3_chen\Desktop\1.xlsx', sheet_name='總表') # 创建GUI窗口 window = tk.Tk() window.title('物料进出库管理') window.geometry('400x200') # 进货函数 def add_inventory(): # 获取物料名称和数量 name = name_entry.get() quantity = int(quantity_entry.get()) # 查找相同名称的数据并进行加操作 group = df.groupby('名稱').sum() if name in group.index: group.loc[name, '數量'] += quantity else: group.loc[name] = [quantity] group.reset_index(inplace=True) # 将修改后的数据写回Excel表格 group.to_excel(r'C:\Users\bing3_chen\Desktop\1.xlsx', index=False, sheet_name='總表', mode='a', header=False) # 清空文本框 name_entry.delete(0, tk.END) quantity_entry.delete(0, tk.END) # 出货函数 def remove_inventory(): # 获取物料名称和数量 name = name_entry.get() quantity = int(quantity_entry.get()) # 查找相同名称的数据并进行减操作 group = df.groupby('名稱').sum() if name in group.index and group.loc[name, '數量'] >= quantity: group.loc[name, '數量'] -= quantity else: messagebox.showerror('Error', '物料不足!') return group.reset_index(inplace=True) # 将修改后的数据写回Excel表格 group.to_excel(r'C:\Users\bing3_chen\Desktop\1.xlsx', index=False, sheet_name='總表', mode='a', header=False) # 清空文本框 name_entry.delete(0, tk.END) quantity_entry.delete(0, tk.END) # 添加控件 tk.Label(window, text='物料名称:').grid(row=0, column=0) name_entry = tk.Entry(window) name_entry.grid(row=0, column=1) tk.Label(window, text='物料数量:').grid(row=1, column=0) quantity_entry = tk.Entry(window) quantity_entry.grid(row=1, column=1) tk.Button(window, text='进货', command=add_inventory).grid(row=2, column=0) tk.Button(window, text='出货', command=remove_inventory).grid(row=2, column=1) window.mainloop()將這個代碼中pabds庫可以修改成openpyxl庫嗎
可以的,只需要将`import pandas as pd`改成`from openpyxl import load_workbook`,然后将读取Excel表格和写回Excel表格的部分修改成openpyxl库的方式即可。修改后的代码如下:
```
import tkinter as tk
from openpyxl import load_workbook
from tkinter import messagebox
# 读取Excel表格数据
wb = load_workbook(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx')
ws = wb['總表']
# 创建GUI窗口
window = tk.Tk()
window.title('物料进出库管理')
window.geometry('400x200')
# 进货函数
def add_inventory():
# 获取物料名称和数量
name = name_entry.get()
quantity = int(quantity_entry.get())
# 查找相同名称的数据并进行加操作
found = False
for row in ws.iter_rows(min_row=2, values_only=True):
if row[0] == name:
row[1] += quantity
found = True
break
if not found:
ws.append([name, quantity])
# 将修改后的数据写回Excel表格
wb.save(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx')
# 清空文本框
name_entry.delete(0, tk.END)
quantity_entry.delete(0, tk.END)
# 出货函数
def remove_inventory():
# 获取物料名称和数量
name = name_entry.get()
quantity = int(quantity_entry.get())
# 查找相同名称的数据并进行减操作
found = False
for row in ws.iter_rows(min_row=2, values_only=True):
if row[0] == name:
if row[1] >= quantity:
row[1] -= quantity
found = True
else:
messagebox.showerror('Error', '物料不足!')
return
if not found:
messagebox.showerror('Error', '物料不存在!')
return
# 将修改后的数据写回Excel表格
wb.save(filename=r'C:\Users\bing3_chen\Desktop\1.xlsx')
# 清空文本框
name_entry.delete(0, tk.END)
quantity_entry.delete(0, tk.END)
# 添加控件
tk.Label(window, text='物料名称:').grid(row=0, column=0)
name_entry = tk.Entry(window)
name_entry.grid(row=0, column=1)
tk.Label(window, text='物料数量:').grid(row=1, column=0)
quantity_entry = tk.Entry(window)
quantity_entry.grid(row=1, column=1)
tk.Button(window, text='进货', command=add_inventory).grid(row=2, column=0)
tk.Button(window, text='出货', command=remove_inventory).grid(row=2, column=1)
window.mainloop()
```