我正在使用进度条通知用户完成文件搜索的进度。实现这一点时,它似乎是当时最合乎逻辑的选择,要获取要搜索的文件数,然后根据该数字创建范围,并根据已搜索的文件进行处理。它似乎工作,但现在我注意到文件搜索完成之前进度条最大化。我是一个Python新手,因此欢迎任何有关如何使其更高效的建议。
以下是我的代码:
...
self.progress_bar = wx.Gauge(self.statusbar, -1, style=wx.GA_HORIZONTAL|wx.GA_SMOOTH)
rect = self.statusbar.GetFieldRect(2)
self.progress_bar.SetPosition((rect.x+2, rect.y+2))
self.progress_bar.SetSize((rect.width-3, rect.height-4))
self.progress_bar.Hide()
...
count = 0
count2 = 0
for afile in filelist:
(head, filename) = os.path.split(afile)
if afile.endswith(".log") or afile.endswith(".txt"):
count2 += 1
self.progress_bar.Show()
self.progress_bar.SetRange(numFiles)
wx.CallAfter(self.progress_bar.SetValue, count2)
f=ftp.open(afile, 'r')
for i, line in enumerate(f.readlines()):
result = regex.search(line)
if self.shouldAbort:
return self.shouldAbort
break
答案 0 :(得分:0)
我认为你应该这样做:
count = 0
count2 = 0
self.progress_bar.Show()
self.progress_bar.SetRange(len(filelist)
for afile in filelist:
(head, filename) = os.path.split(afile)
if afile.endswith(".log") or afile.endswith(".txt"):
f=ftp.open(afile, 'r')
for i, line in enumerate(f.readlines()):
result = regex.search(line)
if self.shouldAbort:
return self.shouldAbort
break
count2 += 1
self.progress_bar.SetValue(count2)