如何在Tkinter中显示可滚动的电子表格?

时间:2017-09-25 10:44:27

标签: python tkinter treeview tk ttk

目前我正在使用Treeview。问题是我使用了相当大的数据集。为了使GUI不大,我限制了Treeview的大小以适应窗口并添加了垂直和水平滚动条。它按照我想要的方式显示数据,但是在每个方向滚动时都存在速度问题。是否有更好/更快的方式来显示类似电子表格的数据。

2 个答案:

答案 0 :(得分:3)

以下解决方案拼凑在一起但应达到预期效果:

from tkinter import *

class App:
    def __init__(self, root):
        self.entry = []
        self.sv = []
        self.root = root
        self.canvas = Canvas(self.root, background="#ffffff", borderwidth=0)
        self.frame = Frame(self.canvas, background="#ffffff")
        self.scrolly = Scrollbar(self.root, orient="vertical", command=self.canvas.yview)
        self.scrollx = Scrollbar(self.root, orient="horizontal", command=self.canvas.xview)
        self.canvas.configure(yscrollcommand=self.scrolly.set)#, xscrollcommand=self.scrollx.set)
        self.canvas.create_window((4,4), window=self.frame, anchor="nw", tags="self.frame")
        self.scrolly.pack(side="left", fill="y")
        self.canvas.pack(side="top", fill="both", expand=True)
        self.scrollx.pack(side="bottom", fill="x")
        self.frame.bind("<Configure>", self.onFrameConfigure)
        for i in range(15):
            self.entry.append([])
            self.sv.append([])
            for c in range(30):
                self.sv[i].append(StringVar())
                self.sv[i][c].trace("w", lambda name, index, mode, sv=self.sv[i][c], i=i, c=c: self.callback(sv, i, c))
                self.entry[i].append(Entry(self.frame, textvariable=self.sv[i][c]).grid(row=c, column=i))
    def onFrameConfigure(self, event):
        self.canvas.configure(scrollregion=self.canvas.bbox("all"))
    def callback(self, sv, column, row):
        print("Column: "+str(column)+", Row: "+str(row)+" = "+sv.get())

root = Tk()
App(root)
root.mainloop()

答案 1 :(得分:2)

我最终使用了pandastable(https://github.com/dmnfarrell/pandastable)。因为它提供了一种快速简便的方式,以电子表格的方式显示数据。它还提供了许多内置功能,例如:排序,过滤和将功能应用于列