如何将tkinter按钮与标签和输入框保持在同一行

时间:2019-02-08 01:00:07

标签: python python-3.x tkinter

我正在创建一个简单的输入UI,以接收2个文本字段和一个文件夹路径。我刚刚开始使用tkinter,但无法使浏览按钮显示在CSV文件的输入字段旁边。而是与其他按钮一起出现。

我已经阅读了tkinter教程。我尝试了来自同事和网络的三种不同的Frame构想。我确实尝试将其放在一个元素中,但是要么我的大脑被炸了,要么我不够好以至于无法理解它是如何工作的。我认为网格可能是我的答案,但是由于这是我尝试过的第一个UI,因此我无法遵循代码。

import tkinter as tk
fields = 'Version', 'Database Name', 'CSV File'

def fetch(entries):
    for entry in entries:
        field = entry[0]
        text  = entry[1].get()
        print('%s: "%s"' % (field, text))

def callback():
    path = tk.filedialog.askopenfilename()
    entry.delete(0, tk.END)
    entry.insert(0, path)

def initUI(root, fields):
    entries = []
    for field in fields:
        if field == 'CSV File':
            frame = tk.Frame(root)
            frame.pack(fill=tk.X)

            lbl = tk.Label(frame, text=field, width=20, anchor='w')
            lbl.pack(side=tk.LEFT, padx=5, pady=5)           

            entry = tk.Entry(frame)
            entry.pack(fill=tk.X, padx=5)

            btn = tk.Button(root, text="Browse", command=callback)
            btn.pack(side=tk.RIGHT,padx=5, pady=5)

            entries.append((field, entry))
        else:
            frame = tk.Frame(root)
            frame.pack(fill=tk.X)

            lbl = tk.Label(frame, text=field, width=20, anchor='w')
            lbl.pack(side=tk.LEFT, padx=5, pady=5)           

            entry = tk.Entry(frame)
            entry.pack(fill=tk.X, padx=5, expand=True)

            entries.append((field, entry))
    return entries

if __name__ == '__main__':
    root = tk.Tk()
    root.title("Helper")
    entries = initUI(root,fields)
    root.bind('<Return>', (lambda event, e=entries: fetch(e))) 
    frame = tk.Frame(root, relief=tk.RAISED, borderwidth=1)
    frame.pack(fill=tk.BOTH, expand=True)

    closeButton = tk.Button(root, text="Close", command=root.quit)
    closeButton.pack(side=tk.RIGHT, padx=5, pady=5)
    okButton = tk.Button(root, text="OK", command=(lambda e=entries: fetch(e)))
    okButton.pack(side=tk.RIGHT)
    root.mainloop()  

我想要输入字段旁边的“浏览”按钮,而不是使用“确定”和“关闭”按钮将其当前位置向下。

侧面问题...我不知道如何使回调工作!

1 个答案:

答案 0 :(得分:1)

  

问题:如何将tkinter按钮与标签和输入框保持在同一行

要达到此目的,您必须packEntry Button到自己的Frame中。

  

注意:始终使用side=tk.LEFT连续获取小部件。

此示例显示了一个OOP解决方案: enter image description here

  • 定义从class LabelEntry继承的tk.Frame

    class LabelEntry(tk.Frame):
        def __init__(self, parent, text, button=None):
            super().__init__(parent)
            self.pack(fill=tk.X)
    
            lbl = tk.Label(self, text=text, width=14, anchor='w')
            lbl.pack(side=tk.LEFT, padx=5, pady=5)
    
  • 条件:如果通过了Button,请为Framepack的{​​{1}}创建一个新的Entry

    Button
  

用法

  • if button: frame2 = tk.Frame(self) frame2.pack(side=tk.LEFT, expand=True) entry = tk.Entry(frame2) entry.pack(side=tk.LEFT, fill=tk.X, padx=5) button.pack(in_=frame2, side=tk.LEFT, padx=5, pady=5) else: entry = tk.Entry(self) entry.pack(side=tk.LEFT, fill=tk.X, padx=5) 定义class App继承。

    tk.Tk
  • 循环class App(tk.Tk): def __init__(self): super().__init__() self.title("Helper") frame = tk.Frame(self) frame.grid(row=0, column=0) 并创建一个fields对象

    LabelEntry
  • 运行应用程序。

            entries = []
            for field in 'Version', 'Database Name', 'CSV File':
                if field == 'CSV File':
                    button = tk.Button(text="Browse", command=self.callback)
                    entries.append(LabelEntry(frame, field, button))
                else:
                    entries.append(LabelEntry(frame, field))
    

使用Python测试:3.5