- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在理解 Progressbar
时遇到了一些麻烦tkinter (python 2.7) 中的小部件我去了 here和 here但我还是不明白如何链接 Progressbar
本身(在“确定”模式下)到我的功能。
有没有人有任何关于如何将功能完成与进度条更新联系起来的例子?我确实研究过这个,我只是找不到任何有用的信息。关于我的(已经可以工作的)代码的注释 - 在代码运行时创建了一个 .txt 文件,该文件打印了函数的总数和正在运行的当前函数。我想链接progressbar
这些 .txt 文件中的信息。
编辑
更具体地说,如何将值更改为正确的数字?
最佳答案
工作示例 - 您可以在两种类型的进度条中看到当前值和最大值。
——
您可以使用 self.var_ind.set()
或 self.var_det.set()
在您的函数中(在类 MainWindow
内)更新进度条。
——
如果你的函数在类之外,你必须用 self.var_ind
调用它或 self.var_det
作为论据。
your_function(self.var_det)
def your_function(progress):
progress.set(10) # set new value
progress.set( progress.get() + 23 ) # add 23 to current value
var_ind.set()
和
self.var_det.set()
在
BEGIN
,
SET 23
,
END
设置新值。
max
在进度条中,您需要添加
self.pbar_ind
或
self.pbar_det
也作为论据。
your_function(self.var_det, self.pbar_det)
def your_function(progress, bar):
bar.config(maximum=200) # set max to 200
bar.step() # add 1 to current value
bar.step(23) # add 23 to current value
progress.set(10) # set new value
progress.set( progress.get() + 23 ) # add 23 to current value
from Tkinter import *
import ttk
class MainWindow(Frame):
def __init__(self):
Frame.__init__(self)
self.master.title("ProgressBar example")
#self.master.minsize(400, 100)
self.grid(sticky=E+W+N+S)
#-----
self.var_ind = IntVar(self)
self.pbar_ind = ttk.Progressbar(self, orient="horizontal", length=400, mode="indeterminate", variable=self.var_ind, maximum=100)
self.pbar_ind.grid(row=0, column=0, pady=2, padx=2, sticky=E+W+N+S, columnspan=3)
Label(self, text="indeterminate").grid(row=1, column=0, pady=2, padx=2, sticky=E+W+N+S)
self.lab_ind_var = Label(self, text="VAR:")
self.lab_ind_var.grid(row=1, column=1, pady=2, padx=2, sticky=E+W+N+S)
self.lab_ind_max = Label(self, text="MAX:")
self.lab_ind_max.grid(row=1, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
self.var_det = IntVar(self)
self.pbar_det = ttk.Progressbar(self, orient="horizontal", length=400, mode="determinate", variable=self.var_det, maximum=100)
self.pbar_det.grid(row=2, column=0, pady=2, padx=2, sticky=E+W+N+S, columnspan=3)
Label(self, text="determinate").grid(row=3, column=0, pady=2, padx=2, sticky=E+W+N+S)
self.lab_det_var = Label(self, text="VAR:")
self.lab_det_var.grid(row=3, column=1, pady=2, padx=2, sticky=E+W+N+S)
self.lab_det_max = Label(self, text="MAX:")
self.lab_det_max.grid(row=3, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="ANIMATION:").grid(row=4, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='START', command=self.animation_start).grid(row=4, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='STOP', command=self.animation_stop).grid(row=4, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="SET:").grid(row=5, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='BEGIN', command=self.set_begin).grid(row=5, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='END', command=self.set_end).grid(row=5, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="SET:").grid(row=6, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='23', command=lambda:self.set(23)).grid(row=6, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='77', command=lambda:self.set(77)).grid(row=6, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="SET:").grid(row=7, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='+23', command=lambda:self.set_plus(23)).grid(row=7, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='-77', command=lambda:self.set_plus(-77)).grid(row=7, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="STEP:").grid(row=8, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='+1', command=lambda:self.step(1)).grid(row=8, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='-10', command=lambda:self.step(-10)).grid(row=8, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
Label(self, text="MAX:").grid(row=9, column=0, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='100', command=lambda:self.max(100)).grid(row=9, column=1, pady=2, padx=2, sticky=E+W+N+S)
Button(self, text='200', command=lambda:self.max(200)).grid(row=9, column=2, pady=2, padx=2, sticky=E+W+N+S)
#-----
self.update_labels_after = False
self.update_labels()
#-----
def animation_start(self):
self.update_labels_after = True
self.pbar_ind.start() # .start(1)
self.pbar_det.start() # .start(1)
self.update_labels()
def animation_stop(self):
self.update_labels_after = False
self.pbar_ind.stop()
self.pbar_det.stop()
self.update_labels()
#-----
def set_begin(self):
self.var_ind.set( 0 )
self.var_det.set( 0 )
self.update_labels()
def set_end(self):
self.var_ind.set( self.pbar_ind.cget('maximum') )
self.var_det.set( self.pbar_det.cget('maximum') )
self.update_labels()
#-----
def set(self, val):
self.var_ind.set( val )
self.var_det.set( val )
self.update_labels()
#-----
def set_plus(self, val):
self.var_ind.set( self.var_ind.get() + val )
self.var_det.set( self.var_det.get() + val )
self.update_labels()
#-----
def step(self, val=1):
self.pbar_ind.step(val) # .step()
self.pbar_det.step(val) # .step()
self.update_labels()
#-----
def max(self, val=1):
self.pbar_ind.config(maximum=val)
self.pbar_det.config(maximum=val)
self.update_labels()
#-----
def update_labels(self):
self.lab_ind_var.config(text='VAR: %d' % (self.var_ind.get()))
self.lab_ind_max.config(text='MAX: %d' % (self.pbar_ind.cget('maximum')))
self.lab_det_var.config(text='VAR: %d' % (self.var_det.get()))
self.lab_det_max.config(text='MAX: %d' % (self.pbar_det.cget('maximum')))
if self.update_labels_after:
self.after(50, self.update_labels)
if __name__=="__main__":
MainWindow().mainloop()
关于python-2.7 - tkinter 进度条 - 链接到功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24769798/
在 How to make a Tkinter window jump to the front? 中提出的问题之后的一个问题 我希望有一个顶层窗口(我用它来导航我的其他主窗口)总是在前面。但我希望它
有没有办法在 Tkinter 中保持小部件(特别是图像)的堆叠顺序一致?例如,我可能在 Canvas 上的同一位置有两个矩形、两个三角形和一个圆。圆圈移动到最后一次点击鼠标的地方,但我总是希望它被绘制
这是一个简单的 GUI 程序,用于创建 5x16 按钮矩阵。 from tkinter import * root = Tk() button = [[0 for x in range(16)] fo
有一个错误:“AttributeError: module 'tkinter' has no attribute 'messagebox'” 即使 import tkinter 一开始就已经给出了,为
我知道 menu.tk_popup() 可用于在特定坐标处打开上下文菜单,但也不知道如何从中打开子菜单,如果这有意义的话。这是我编写的代码: import tkinter as tk root = t
我正在尝试在禁用自动换行和水平滚动条的文本窗口中书写,如下所示: root = Toplevel() root.geometry("%dx%d+0+0" % (350,400)) af=Frame(r
已经将文本变量分配给小部件后,如何将其删除? widget.config(textvariable=None)只是不工作。在谷歌或这里找不到任何东西。 最佳答案 将您的变量分配给一个空字符串以实现此目
Jython 支持 Tkinter 吗?如果我用 Python 编写一个程序并放一个 使用 Tkinter 的 GUI 前端,做同样的事情有多难 Jython 中的程序?或者对于 Jython GUI
因此,我尝试创建一个 tkinter 窗口,显示当前时间和日期以及自定义短语。不过,我遇到的问题是,我似乎无法在第二天刷新日期。 我可以传递截至运行代码时的当前日期,但之后它变为静态。 这是我目前的程
我的理解是在初始化 __init__ 中的所有框架和小部件之后方法,tkinter 窗口会调整大小以适合所有这些组件。 我想将窗口的初始化大小设置为其最小大小。我希望能够最大化并放大窗口,但我从不希望
此代码仅水平居中,如何使进度条也垂直居中? import Tkinter import ttk root = Tkinter.Tk() root.geometry("=500x500") root.p
使用 Python 2.7 和 Tkinter 模块,我创建了一个菜单按钮并为其分配了一个菜单。现在每次我在特定位置发布菜单时,菜单的宽度都会根据字符数自动设置。有没有办法在菜单小部件中设置静态宽度?
我想将我的 tkinter 应用程序的主题更改为 clam。 代码是什么,我把它放在哪里?我试过了: from tkinter import * from tkinter.ttk import * s
我有以下代码: from Tkinter import * from urllib import urlretrieve import webbrowser import ttk def get_la
我知道,如果我将滚动条控制的框架绑定(bind)到函数 ( onFrameConfigure ),您可以获得滚动条位置,如下所示:self.calendar_frame.bind("", self.o
许多网站都说菜单小部件有一个选项“字体”,但我一直无法设置它。系统是在 Windows 8.1 中运行的 Python 3.5。脚本开始: 从 tkinter 导入 * 根 = Tk() root.g
我正在阅读本教程,它帮助我同时学习 tkinter 和 wxWidgets,但我想深入挖掘,所以想知道哪个 GUI 工具更适合深入学习,为什么? 最佳答案 不可能说哪个“更好”。两者均可用于最常见的用
看书学python,tkinter.END用在一段代码里不用解释 import tkinter def count(text, out_data): """ Update out_data w
我正在尝试使用 Python 2.7 将 Tkinter 导入到我的项目中,但我收到了错误: ImportError: No module named tkinter 在有人说之前,我已经尝试了“Tk
当我回答 Tkinter 问题时,我通常会尝试自己运行代码,但有时我会收到此错误: Traceback (most recent call last): File "C:\Python27\pyg
我是一名优秀的程序员,十分优秀!