滚动条在Tkinter中使用网格布局滚动文本小部件

时间:2015-05-28 21:05:34

标签: python tkinter

我正在尝试使用Tkinter中的网格布局管理器来创建一个对话框。 我希望底部的文本区域有一个滚动条。不幸的是,我无法弄清楚如何使滚动条与它旁边的文本小部件的高度相同。下面的示例显示滚动条位于正确位置但尺寸错误(仅占Text小部件高度的10%左右)。

layout issue with tkinter grid and scrollbar

from tkinter import *

class queryrunner(Tk):
    def __init__(self,parent):
        Tk.__init__(self,parent)
        self.parent = parent
        self.minsize(width=800,height=500)
        self.initialize()

    def initialize(self):
        self.grid_columnconfigure(2,weight=1)
        self.grid_columnconfigure(3,weight=1)
        self.grid_columnconfigure(6,weight=2)
        self.grid_rowconfigure(0,weight=1)
        self.grid_rowconfigure(1,weight=1)
        self.grid_rowconfigure(2,weight=1)
        self.grid_rowconfigure(3,weight=1)
        self.grid_rowconfigure(4,weight=1)
        # BUCKET AND N1QL LABEL + INPUT PAIRS: 
        self.label = Label(self,text="Bucket", width=10, anchor="w")
        self.label.grid(column=0,row=0,columnspan=1,sticky='W')
        self.entry = Entry(self);
        self.entry.grid(column=1,row=0, columnspan=3, sticky='EW')
        self.entry.insert(0, "couchbase://couchbase1.mycompany.com/beer-sample" )
        # EXECUTE N1QL QUERY AGAINST BUCKET WHEN BUTTON CLICKED:
        self.button = Button(self,text="Go",width=20)
        self.button.grid(column=6,row=0)
        self.label2 = Label(self,text="N1QL", anchor="w")
        self.label2.grid(column=0,row=1,columnspan=1,sticky='W')
        self.entry2 = Text(self,height=5);
        self.entry2.grid(column=1,row=1, columnspan=3, rowspan=1, sticky='W')

        self.label3 = Label(self,text="Output:", width=50,anchor="w")
        self.label3.grid(column=0,row=4,columnspan=5,sticky='W')
        self.entry3 = Text(self,height=18)
        self.entry3.grid(column=1,row=5, columnspan=5, rowspan=1, sticky='W')
        # PROBLEM: GET SCROLLBAR TO BE THE RIGHT SIZE (IT'S NOT THE SIZE OF THE THING ITS BESIDE)
        self.scrollbar = Scrollbar(self) # height= not permitted here!
        self.entry3.config(yscrollcommand= self.scrollbar.set)
        self.scrollbar.config(command= self.entry3.yview)
        self.grid()
        self.scrollbar.grid(column=6, row=5, rowspan=2,  sticky='W')


if __name__ == "__main__":
    app = queryrunner(None)
    #font.nametofont('TkDefaultFont').configure(size = 10 )
    app.title('Couchbase N1QL Query Runner')
    app.mainloop()

3 个答案:

答案 0 :(得分:11)

将North和South添加到Scrollbar网格调用的粘性选项,以便滚动条在垂直方向上拉伸。

self.scrollbar.grid(column=6, row=5, rowspan=2,  sticky=N+S+W)

答案 1 :(得分:2)

您只能在容器的每个子窗口小部件上使用一个几何管理器,但如果子窗口小部件本身就是一个容器,则可以使用您喜欢的任何几何管理器作为其子窗口。这意味着我们只需Framepack()EntryScrollbar加入其中,使用fill='y'参数进行Scrollbar填充可用空间。

改变这个:

self.entry3 = Text(self,height=18)
self.entry3.grid(column=1,row=5, columnspan=5, rowspan=1, sticky='W')
# PROBLEM: GET SCROLLBAR TO BE THE RIGHT SIZE (IT'S NOT THE SIZE OF THE THING ITS BESIDE)
self.scrollbar = Scrollbar(self) # height= not permitted here!
self.entry3.config(yscrollcommand= self.scrollbar.set)
self.scrollbar.config(command= self.entry3.yview)
self.grid()
self.scrollbar.grid(column=6, row=5, rowspan=2,  sticky='W')

到此:

self.frame = Frame(self)
self.frame.grid(column=1,row=5, columnspan=6, rowspan=1, sticky='W')
self.entry3 = Text(self.frame,height=18)
self.entry3.pack(side='left', fill='both', expand=True)
# PROBLEM: SOLVED
self.scrollbar = Scrollbar(self.frame) # height= not permitted here!
self.entry3.config(yscrollcommand= self.scrollbar.set)
self.scrollbar.config(command= self.entry3.yview)
self.grid()
self.scrollbar.pack(side='right', fill='y')

答案 2 :(得分:1)

有ScrolledText模块。

如果您使用的是Anaconda python发行版,请在 conda install ScrolledText 命令行中执行:

 from tkinter.scrolledtext import ScrolledText

然后在.py文件导入模块中(如果是python 3及以上)

 import ScrolledText

如果是python 2.7那么

{{1}}

然后在python 3中将其称为普通的Text小部件:

  

self.textBox = ScrolledText(self,borderwidth = 3,relief =" sunken")

这是一个复合小工具(文字和滚动条)。