Tkinter如何制作一个工具?

联系人管理系统

我们可以在项目中进行许多操作,例如:

1.添加新联系人。

  1. 使用手机号码或姓名或地址查找特定记录。

  2. 显示所有记录。

  3. 使用某人的电子邮件编辑特定记录。

  4. 删除一个人的mailId记录。

信息存储在数据库文件中。

使用的包:
我们在这段代码中使用的包是 sqlite3,tkinter
仅支持Mac

from tkinter import *
from tkinter import ttk

from sqlite3 import *
from tkinter import messagebox
from ttkbootstrap import *

class Contact:
    def __init__(self, root):
        self.root = root
        self.root.title("contacts Management System")
        self.root.geometry("1400x750+10+10")

        title = Label(self.root, text="Contacts Book",relief=GROOVE, font=("times new roman", 30, "bold"))
        title.pack(side=TOP, fill=X)
        lbl_footer = Label(self.root, text="Developed by M.Jyotsna Manasa", font=("goudy old style", 15, "bold"))\
            .place(x=0, y=710, relwidth=1, height=40)

        self.name_var = StringVar()
        self.email_var = StringVar()
        self.gender_var = StringVar()
        self.mobileNo_var = StringVar()
        self.teleNo_var = StringVar()
        self.dob_var = StringVar()
        self.address_var = StringVar()
        self.search_by = StringVar()
        self.search_txt = StringVar()

        # manage frame
        Manage_Frame = Frame(self.root, relief=RIDGE)
        Manage_Frame.place(x=10, y=100, width=500, height=600)
        m_title = Label(Manage_Frame, text="Manage contacts",
                        font=("times new roman", 20, "bold"))
        m_title.grid(row=0, columnspan=2, pady=15)

        lbl_name = Label(Manage_Frame, text="Name *",font=("times new roman", 15, "bold"))
        lbl_name.grid(row=1, column=0, pady=5, padx=30, sticky="w")
        txt_name = Entry(Manage_Frame, textvariable=self.name_var, font=("times new roman", 15, "bold"))
        txt_name.grid(row=1, column=1, pady=5, padx=30, sticky="w")

        lbl_email = Label(Manage_Frame, text="Email *",
                          font=("times new roman", 15, "bold"))
        lbl_email.grid(row=2, column=0, pady=5, padx=30, sticky="w")
        txt_email = Entry(Manage_Frame, textvariable=self.email_var, font=("times new roman", 15, "bold"),
                          )
        txt_email.grid(row=2, column=1, pady=5, padx=30, sticky="w")

        lbl_gender = Label(Manage_Frame, text="Gender *",
                           font=("times new roman", 15, "bold"))
        lbl_gender.grid(row=3, column=0, pady=5, padx=30, sticky="w")
        combo_gender = ttk.Combobox(Manage_Frame, textvariable=self.gender_var, font=("times new roman", 13, "bold"),
                                    state="readonly")
        combo_gender['values'] = ("Male", "Female", "Other")
        combo_gender.grid(row=3, column=1, padx=30, pady=5, sticky="w")

        lbl_mobileNo = Label(Manage_Frame, text="Mobile No *",
                             font=("times new roman", 15, "bold"))
        lbl_mobileNo.grid(row=4, column=0, pady=5, padx=30, sticky="w")
        txt_mobileNo = Entry(Manage_Frame, textvariable=self.mobileNo_var, font=("times new roman", 14, "bold"),
                             )
        txt_mobileNo.grid(row=4, column=1, pady=5, padx=30, sticky="w")

        lbl_mobileNo = Label(Manage_Frame, text="Tele No",
                             font=("times new roman", 15, "bold"))
        lbl_mobileNo.grid(row=5, column=0, pady=5, padx=30, sticky="w")
        txt_mobileNo = Entry(Manage_Frame, textvariable=self.teleNo_var, font=("times new roman", 14, "bold")
                             )
        txt_mobileNo.grid(row=5, column=1, pady=5, padx=30, sticky="w")

        lbl_dob = Label(Manage_Frame, text="D.O.B *",font=("times new roman", 15, "bold"))
        lbl_dob.grid(row=6, column=0, pady=5, padx=30, sticky="w")
        txt_dob = Entry(Manage_Frame, textvariable=self.dob_var, font=("times new roman", 15, "bold"),
                        )
        txt_dob.grid(row=6, column=1, pady=5, padx=30, sticky="w")

        lbl_address = Label(Manage_Frame, text="Address *",
                            font=("times new roman", 15, "bold"))
        lbl_address.grid(row=7, column=0, pady=5, padx=30, sticky="w")
        self.txt_address = t = Text(Manage_Frame, width=30, height=4, font=("", 10))
        self.txt_address.grid(row=7, column=1, pady=5, padx=30, sticky="w")

        lbl_msg = Label(Manage_Frame, text="* means Required fields",
                        font=("times new roman", 15, "bold"))
        lbl_msg.grid(row=8, columnspan=2, pady=30)

        Btn_Frame = Frame(Manage_Frame)
        Btn_Frame.place(x=8, y=530, width=480)
        addbtn = Button(Btn_Frame, text="Add", width=10,
                        command=self.add_contacts).grid(row=0, column=0, padx=5, pady=5)
        updatebtn = Button(Btn_Frame, text="Update",
                           width=10, command=self.update_data).grid(row=0, column=1, padx=5, pady=5)

        deletebtn = Button(Btn_Frame, text="Delete",
                           width=10, command=self.delete_data).grid(row=0, column=2, padx=5, pady=5)
        clearbtn = Button(Btn_Frame, text="Clear",
                          width=10, command=self.clear).grid(row=0, column=3, padx=5, pady=5)

        # detail frame
        Details_Frame = Frame(self.root)
        Details_Frame.place(x=525, y=100, width=850, height=600)

        lbl_search = Label(Details_Frame, text="Search")
        lbl_search.grid(row=0, column=0, pady=10, padx=30, sticky="w")
        combo_search = ttk.Combobox(Details_Frame, width=10, textvariable=self.search_by,
                                     state="readonly")
        combo_search['values'] = ("Name", "MobileNo", "Address")
        combo_search.grid(row=0, column=1, padx=30, pady=10, sticky="w")
        txt_search = Entry(Details_Frame, textvariable=self.search_txt, width=20)
        txt_search.grid(row=0, column=2, pady=10, padx=30, sticky="w")
        searchbtn = Button(Details_Frame, text="Search",
                           command=self.search_data, width=10).grid(row=0, column=3, padx=10, pady=10)
        showallbtn = Button(Details_Frame, text="Showall",
                            command=self.fetch_data, width=10).grid(row=0, column=4, padx=10, pady=10)

        # Table frame
        Table_Frame = Frame(Details_Frame)
        Table_Frame.place(x=10, y=70, width=800, height=500)
        scroll_x = Scrollbar(Table_Frame, orient=HORIZONTAL)
        scroll_y = Scrollbar(Table_Frame, orient=VERTICAL)
        self.contacts_table = ttk.Treeview(Table_Frame, columns=(
        "Name", "Email", "Gender", "Mobile No", "Tele No", "DOB", "Address"), xscrollcommand=scroll_x.set,
                                           yscrollcommand=scroll_y.set)
        scroll_x.pack(side=BOTTOM, fill=X)
        scroll_y.pack(side=RIGHT, fill=Y)
        scroll_x.config(command=self.contacts_table.xview)
        scroll_y.config(command=self.contacts_table.yview)

        self.contacts_table.heading("Name", text="Name")

        self.contacts_table.heading("Email", text="Email")
        self.contacts_table.heading("Gender", text="Gender")
        self.contacts_table.heading("Mobile No", text="Mobile No")
        self.contacts_table.heading("Tele No", text="Tele No")

        self.contacts_table.heading("DOB", text="dob")
        self.contacts_table.heading("Address", text="Address")
        self.contacts_table['show'] = "headings"

        self.contacts_table.column("Name", width=150)

        self.contacts_table.column("Email", width=150)
        self.contacts_table.column("Gender", width=100)
        self.contacts_table.column("Mobile No", width=150)
        self.contacts_table.column("Tele No", width=150)
        self.contacts_table.column("DOB", width=150)
        self.contacts_table.column("Address", width=150)
        self.contacts_table.pack(fill=BOTH, expand=1)
        self.contacts_table.bind("<ButtonRelease-1>", self.get_cursor)
        self.fetch_data()

    def add_contacts(self):
        if (
                self.name_var.get() == "" or self.email_var.get() == "" or self.gender_var.get() == "" or self.mobileNo_var.get() == "" or self.dob_var.get() == "" or self.txt_address.get(
                '1.0', END) == ""):
            messagebox.showerror("Error", "Required fields are not filled")
        else:
            conn = connect("contacts.db")
            cur = conn.cursor()
            cur.execute("insert into contacts values(?,?,?,?,?,?,?)", (
            self.name_var.get(), self.email_var.get(), self.gender_var.get(), self.mobileNo_var.get(),
            self.teleNo_var.get(), self.dob_var.get(), self.txt_address.get('1.0', END)))
            conn.commit()
            self.fetch_data()
            self.clear()
            conn.close()
            messagebox.showinfo("Success", "Successfully added")

    def fetch_data(self):
        conn = connect("contacts.db")
        cur = conn.cursor()
        cur.execute("SELECT * FROM contacts")
        rows = cur.fetchall()
        if len(rows) != 0:
            self.contacts_table.delete(*self.contacts_table.get_children())
            for row in rows:
                self.contacts_table.insert('', END, values=row)
            conn.commit()
        conn.close()

    def clear(self):

        self.name_var.set("")
        self.email_var.set("")
        self.gender_var.set("")
        self.mobileNo_var.set("")
        self.teleNo_var.set("")
        self.dob_var.set("")
        self.txt_address.delete("1.0", END)

    def get_cursor(self, ev):
        cursor_row = self.contacts_table.focus()
        content = self.contacts_table.item(cursor_row)
        row = content['values']

        self.name_var.set(row[0])

        self.email_var.set(row[1])
        self.gender_var.set(row[2])
        self.mobileNo_var.set(row[3])
        self.teleNo_var.set(row[4])
        self.dob_var.set(row[5])
        self.txt_address.delete("1.0", END)
        self.txt_address.insert(END, row[6])

    def update_data(self):
        if (
                self.name_var.get() == "" or self.email_var.get() == "" or self.gender_var.get() == "" or self.mobileNo_var.get() == "" or self.dob_var.get() == "" or self.txt_address.get(
                '1.0', END) == ""):
            messagebox.showerror("Error", "Required fields are not filled")
        else:
            conn = connect("contacts.db")
            cur = conn.cursor()

            cur.execute("update contacts set Name=?,Gender=?,MobileNo=?,TeleNo=?,DateOfBirth=?,address=? WHERE Email=?",
                        (self.name_var.get(), self.gender_var.get(), self.mobileNo_var.get(), self.teleNo_var.get(),
                         self.dob_var.get(), self.txt_address.get('1.0', END), self.email_var.get()))
            conn.commit()
            self.fetch_data()
            self.clear()
            conn.close()
            messagebox.showinfo("Success", "Successfully updated")

    def delete_data(self):
        if (
                self.name_var.get() == "" or self.email_var.get() == "" or self.gender_var.get() == "" or self.mobileNo_var.get() == "" or self.dob_var.get() == "" or self.txt_address.get(
                '1.0', END) == ""):
            messagebox.showerror("Error", "Required fields empty")
        else:
            conn = connect("contacts.db")
            cur = conn.cursor()
            sql_query = f"delete FROM contacts where MobileNo={self.mobileNo_var.get()}"

            cur.execute(sql_query)

            conn.commit()
            conn.close()
            self.clear()
            self.fetch_data()
            messagebox.showinfo("Success", "Successfully Deleted")

    def search_data(self):
        conn = connect("contacts.db")
        cur = conn.cursor()
        sql_query = f"SELECT * FROM contacts where {self.search_by.get()} like '%{self.search_txt.get()}%'"

        cur.execute(sql_query)
        rows = cur.fetchall()
        if len(rows) != 0:
            self.contacts_table.delete(*self.contacts_table.get_children())
            for row in rows:
                self.contacts_table.insert('', END, values=row)
            conn.commit()
        else:
            messagebox.showerror("Error", "No Data available")
            self.search_by.set("")
            self.search_txt.set("")
        conn.close()


root = Tk()
con = connect('contacts.db')
cur = con.cursor()
cur.execute(
    "CREATE TABLE IF NOT EXISTS contacts(Name text NOT NULL, Email text NOT NULL,Gender text NOT NULL,MobileNo integer(10) NOT NULL,teleNo integer(10) ,DateOfBirth text, Address text NOT NULL); ")
con.commit()
con.close()
ob = Contact(root)
root.mainloop()

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPython等GUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ko-walski

太难了,求鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值