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()TypeError: NDFrame.to_excel() got an unexpected keyword argument 'mode報這個錯誤怎麽修改
时间: 2024-03-05 21:48:32 浏览: 65
这个错误是因为 `to_excel()` 方法中没有 `mode` 这个参数,所以需要将 `mode` 参数删除或替换为其他合适的参数。这里的 `mode` 参数是想要将数据添加到现有文件中,因此可以将 `mode` 参数替换为 `append`。
修改后的代码如下:
```python
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='append', 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='append', 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()
```
阅读全文