Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Python Progress Bar ValueError: Value out of range

My progress bar reaches 100% and then throws the error

from progressbar import Percentage, ProgressBar,Bar,ETA

pbar = ProgressBar(widgets=[Bar('=', '[', ']'), ' ',
                                            Percentage(), ' ',
                                            ETA()]).start()
            for i,row in enumerate(cursor):

               '''
                do some work here

               ''' 

                pbar.update(i)

here is what i get

Traceback (most recent call last):=========================] 100% ETA:  0:00:00
  File "X:\src\dbtest\PymssqlCheck.py", line 27, in <module>
    fiddler.getRows(condetails, dbdetails, 'compliance', 'doctable', '*', '1000')
  File "X:\src\utilities\fiddler.py", line 45, in getRows
    pbar.update(i)
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 271, in update
    raise ValueError('Value out of range')
ValueError: Value out of range

why does it reach 100% and then fail? i am using

https://github.com/niltonvolpato/python-progressbar

i even tried

 i=0                                
            for row in cursor:

                ''' do some work here ''' 

                if i < numrows:
                    pbar.update(i)
                    i=i+1

but i still get the same error

Edit

i tried Tomasz Jakub Rup answer

pbar = ProgressBar(widgets=[Bar('=', '[', ']'), ' ',
                                        Percentage(), ' ',
                                        ETA()])
for row in pbar(cursor):
    ''' do some work here ''' 

and i get

File "X:\fiddler.py", line 41, in getRows
    for row in pbar(cursor):
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 180, in __next__
    if self.start_time is None: self.start()
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 311, in start
    self.update(0)
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 283, in update
    self.fd.write(self._format_line() + '\r')
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 243, in _format_line
    widgets = ''.join(self._format_widgets())
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 223, in _format_widgets
    widget = format_updatable(widget, self)
  File "X:\Anaconda2\lib\site-packages\progressbar\widgets.py", line 38, in format_updatable
    if hasattr(updatable, 'update'): return updatable.update(pbar)
  File "X:\Anaconda2\lib\site-packages\progressbar\widgets.py", line 184, in update
    return '%3d%%' % pbar.percentage()
  File "X:\Anaconda2\lib\site-packages\progressbar\__init__.py", line 208, in percentage
    return self.currval * 100.0 / self.maxval
TypeError: unsupported operand type(s) for /: 'float' and 'classobj'

any idea why?

like image 782
AbtPst Avatar asked Nov 20 '15 19:11

AbtPst


2 Answers

David and Tomasz, both of you guys came pretty close. the solution that worked is

pbar = ProgressBar(widgets=[Bar('>', '[', ']'), ' ',
                                            Percentage(), ' ',
                                            ETA()],maxval=someMaxValue)
            for row in pbar(cursor):
                ''' do some work '''
like image 142
AbtPst Avatar answered Oct 21 '22 11:10

AbtPst


Because the progress bar is full a 100 by default. You should specify a maxval=N if you have N steps.

For example:

from progressbar import Percentage, ProgressBar,Bar,ETA

N = 300

pbar = ProgressBar(widgets=[Bar('=', '[', ']'), ' ', Percentage(), ' ', ETA()],
                   maxval=N).start()

for i in range(N+1):
    pbar.update(i)
like image 26
David Froger Avatar answered Oct 21 '22 12:10

David Froger