Задать вопрос

Почему Выдает ошибку, Python?

import tkinter as tk
import sqlite3
from tkinter import ttk, simpledialog, messagebox

class ManageApp():
def init(self, master):
self.master = master
self.master.title("Manage App")

self.conn = sqlite3.connect('employees.db')
self.create_table()

self.tree = ttk.Treeview(master)
self.tree["columns"] = ("ID", "Name", "Phone", "Email", "Salary")
self.tree.heading("ID", text="ID")
self.tree.heading("Name", text="Name")
self.tree.heading("Phone", text="Phone")
self.tree.heading("Email", text="Email")
self.tree.heading("Salary", text="Salary")
self.tree.pack(padx=30, pady=30)

self.create_widgets()
self.update_treeview()

def create_table(self):
cursor = self.conn.cursor()
cursor.execute('''CREATE TABLE IF NOT EXSISTS Employees (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT,
phone TEXT,
email TEXT,
salary INTEGER
)''')
self.conn.commit()

def create_widgets(self):
self.add_button = tk.Button(self.master, text="Add Employee", command=self.add_employee)
self.add_button.pack(pady=10)
self.update_button = tk.Button(self.master, text="Update Employee", command=self.update_employee)
self.update_button.pack(pady=10)
self.delete_button = tk.Button(self.master, text="Delete Employee", command=self.delete_employee)
self.delete_button.pack(pady=10)
self.search_button = tk.Button(self.master, text="Search Employee", command=self.search_employee)
self.search_button.pack(pady=10)
self.undo_button = tk.Button(self.master, text="Undo", command=self.undo_action)
self.undo_button.pack(pady=10)

self.tree.bind("", self.on_double_click) #Привязать событие двойного щелчка на treeview

self.last_action = None #Чтобы сохранить последнее действие для отмен

def add_employee(self):
name = simpledialog.askstring("Input", "Enter employee name:")
phone = simpledialog.askstring("Input", "Enter employee phone:")
email = simpledialog.askstring("Input", "Enter employee email:")
salary = simpledialog.askinteger("Input", "Enter employee salary:")

cursor = self.conn.cursor()
cursor.execute("INSERT INTO employees (name, phone, email, salary) VALUES (?, ?, ?, ?)", (name, phone, email, salary))
self.conn.commit()
self.update_treeview()
self.last_action = "add"

def update_employee(self):
emp_id = simpledialog.askinteger("Input", "Enter employee ID:")

cursor = self.conn.cursor()
cursor.execute("SELECT * FROM employees WHERE id=?", (emp_id,))
employee = cursor.fetchone()

if employee:
name = simpledialog.askstring("Input", "Enter updated employee name:", initialvalue=employee[1])
phone = simpledialog.askstring("Input", "Enter updated employee phone:", initialvalue=employee[2])
email = simpledialog.askstring("Input", "Enter updated employee email:", initialvalue=employee[3])
salary = simpledialog.askinteger("Input", "Enter updated employee salary:", initialvalue=employee[4])

cursor.execute("UPDATE employees SET name=?, phone=?, email=?, salary=? WHERE id=?", (name, phone, email, salary, emp_id))
self.conn.commit()
self.update_treeview()
self.last_action = "update"
else:
messagebox.showerror("Error", "Employee not found.")

def delete_employee(self):
emp_id = simpledialog.askinteger("Input", "Enter employee ID:")

cursor = self.conn.cursor()
cursor.execute("DELETE FROM employees WHERE id=?", (emp_id,))
self.conn.commit()
self.update_treeview()
self.last_action = "delete"
def search_employee(self):
name = simpledialog.askstring("Input", "Enter employee name:")

cursor = self.conn.cursor()
cursor.execute("SELECT * FROM employees WHERE name=?", (name,))
employees = cursor.fetchall()

if employees:
self.tree.delete(*self.tree.get_children())
for employee in employees:
self.tree.insert("", "end", values=employee)
else:
messagebox.showinfo("Info", "No employee found with the given name.")

def update_treeview(self):
#Очистка Treeview
for item in self.tree.get_children():
self.tree.delete(item)

cursor = self.conn.cursor()
cursor.execute("SELECT * FROM employees")
employees = cursor.fetchall()

for employee in employees:
self.tree.insert("", "end", values=employee)

def on_double_click(self, event):
item = self.tree.selection()[0]
employee_id = self.tree.item(item, "values")[0] # Получить ID сотрудника
messagebox.showinfo("Employee ID", f"Employee ID: {employee_id}")

def undo_action(self):
if self.last_action == "add":
messagebox.showinfo("Undo", "Undo Add Employee action")
#Реализую код, чтобы отменить действие добавления
elif self.last_action == "update":
messagebox.showinfo("Undo", "Undo Update Employee action")
#Реализую код, чтобы отменить действие обновления
elif self.last_action == "delete":
messagebox.showinfo("Undo", "Undo Delete Employee action")
#Реализую код, чтобы отменить действие удаления
else:
messagebox.showinfo("Undo", "No previous action to undo")

def on_closing(self):
self.conn.close()
self.master.destroy()

if __name__ == "__main__":
root = tk.Tk()
app = ManageApp(root)
root.protocol("WM_DELETE_WINDOW", app.on_closing)
root.mainloop()

app = ManageApp(root)
Type error: ManageApp() takes no arguments
Помогите как исправить
  • Вопрос задан
  • 128 просмотров
Подписаться 1 Простой 5 комментариев
Пригласить эксперта
Ответы на вопрос 2
Maksim_64
@Maksim_64
Data Analyst
def init(self, master): Вот здесь ты определил метод экземпляра класса init. А хотел переопределить конструктор экземпляра класса, то есть def __init__(self, master): Отсюда при попытке создания экземпляра класса app = ManageApp(root) он говорит что параметров быть не должно, потому что конструктор экземпляра класса остался пустым.
Ответ написан
@codingoleg
Потому что неправильный синтаксис. Не class ManageApp(), а class ManageApp должно быть.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы