Tkinter ProgressBar和Os.Walk-in Python 2.7

Tkinter ProgressBar和Os.Walk-in Python 2.7,python,python-2.7,tkinter,progress-bar,os.walk,Python,Python 2.7,Tkinter,Progress Bar,Os.walk,我有一个工作的GUI和一个不稳定的进度条。我的问题似乎是,我无法根据源目录中的项目数量使进度条正确运行。有什么想法吗 def Progress(self): progress = Frame(self) progress.pack(fill=X) self.progressLine = ttk.Progressbar(progress, orient=HORIZONTAL, length=550, mode='determinate', maximum=100)

我有一个工作的GUI和一个不稳定的进度条。我的问题似乎是,我无法根据源目录中的项目数量使进度条正确运行。有什么想法吗

def Progress(self):
    progress = Frame(self)
    progress.pack(fill=X)
    self.progressLine = ttk.Progressbar(progress, orient=HORIZONTAL, length=550, mode='determinate', maximum=100)
    self.progressLine.pack(pady=5)

def Scatter(self):
    self.t_start.delete('1.0', END)
    if Entry.get(self.sourceE) > 0 or Entry.get(self.destE) > 0:
        if not os.path.exists(Entry.get(self.sourceE)) or not os.path.exists(Entry.get(self.destE)):
            self.t_start.delete('1.0', END)
            self.t_start.insert(END, '*WARNING* Missing Source and/or Destination Folders')
            return

    self.t_start.delete('1.0', END)
    self.t_start.insert(END, "Counting Assets\n")
    self.totalFiles = len(list(os.walk(os.path.abspath(Entry.get(self.sourceE)))))
    self.stepFiles = (100/self.totalFiles)
    self.progressLine['value'] = self.stepFiles
    self.t_start.insert(END, "Process Started...\n")
    #self.progressLine.step(self.stepFiles)

    for root, subFolders, files in os.walk(Entry.get(self.sourceE)):
        self.progressLine.step(self.stepFiles)
        for file in files:
            if not file.startswith('.'):
                subFolder = os.path.join(Entry.get(self.destE), file[:1], file[:2], file [:3], file [:4])
                checkFile = os.path.join(subFolder, file)
                if not os.path.isdir(subFolder):
                    os.makedirs(subFolder)
                if not os.path.exists(checkFile):
                    shutil.move(os.path.join(root, file), subFolder)
                else:
                    global fname, fextension
                    fname, fextension = os.path.splitext(file)
                    ii = 1
                    while True:
                        new_pname = os.path.join(subFolder, fname + "_" + str(ii) + fextension)
                        new_name = fname + "_" + str(ii) + fextension
                        if not os.path.exists(new_pname):
                            shutil.copy(checkFile, new_pname)
                            change_files = "From: " + file + " to: " + new_name + "\n"
                            self.t_start.insert(END, change_files)
                            if self.CheckVar.get() == 1:
                                delfile = os.path.join(root, file)
                                delete_files = "Deleted Original: " + file + "\n"
                                self.t_start.insert(END, delete_files)
                                os.remove(delfile)
                            break
                        ii += 1
            self.progressLine.update_idletasks()
    self.t_start.insert(END, "Process Complete")
    self.progressLine.update_idletasks()
一切正常,我唯一的问题是“stepFiles”变量。我将如何使这比我已经拥有的更准确


也许这就是我计算STEP文件的方式?我觉得我遗漏了一些简单的东西。

在Python中用2个整数进行除法时,会得到一个整数。例如,如果您有27个文件:

>>> 100 / 27
3
现在我们可以看到这里有一个巨大的问题,因为
3*27==81
。因此,如果我们在27个文件中按3步执行,您只会以81%的完整进度条结束

您可以通过将一个浮点数输入分区来解决此问题,以获得更准确的结果:

>>> 100.00 / 27
3.7037037037037037
--


解决此问题的另一种方法是将progressbar的
最大值设置为
self.totalFiles
(当然,在您计算之后),然后为每个文件逐步设置
1

我从self.progressLine中删除了maximum=100,取出self.stepFiles=(100/self.totalFiles),并设置self.progressLine[“maximum”]=self.totalFiles。但是,当代码运行时,进度条似乎仍然处于最大值,并一次又一次地重新启动。-我觉得我调用step的次数太多了?您需要更改的只是
self.stepFiles
self.stepFiles=(100.00/self.totalFiles)
如果您选择了第二条路线,那么您还需要更改到
self.progressLine.step(1)
我必须重新调整一些代码以使其正确执行步骤,但这确实奏效了!