use callback for tasks instead of adding extra function
This commit is contained in:
		
							parent
							
								
									46c4faf118
								
							
						
					
					
						commit
						91883e0133
					
				| @ -2,6 +2,7 @@ from collections import Counter | |||||||
| from concurrent.futures import ThreadPoolExecutor, as_completed | from concurrent.futures import ThreadPoolExecutor, as_completed | ||||||
| from progress.bar import Bar | from progress.bar import Bar | ||||||
| import sys | import sys | ||||||
|  | import functools | ||||||
| 
 | 
 | ||||||
| from imdb_utils import IMDbUtils | from imdb_utils import IMDbUtils | ||||||
| from bookstack import Bookstack | from bookstack import Bookstack | ||||||
| @ -49,18 +50,17 @@ def get_vcinema_viewings(token_id, token_secret, combine_repeat_viewings=True): | |||||||
|     return viewings |     return viewings | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def get_imdb(imdb_id, bar): | def increment_progressbar(bar, _): | ||||||
|     imdb_entry = IMDbUtils.get_movie(imdb_id) |  | ||||||
| 
 |  | ||||||
|     if bar is not None: |  | ||||||
|     bar.next() |     bar.next() | ||||||
| 
 | 
 | ||||||
|     return imdb_entry |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| def add_imdb_data_to_viewings(viewings, field_names, progressbar=None): | def add_imdb_data_to_viewings(viewings, field_names, progressbar=None): | ||||||
|     with ThreadPoolExecutor(4) as executor: |     with ThreadPoolExecutor(4) as executor: | ||||||
|         future_to_url = {executor.submit(get_imdb, viewing['imdb_id'], progressbar) for viewing in viewings} |         future_to_url = {executor.submit(IMDbUtils.get_movie, viewing['imdb_id']) for viewing in viewings} | ||||||
|  | 
 | ||||||
|  |         if progressbar is not None: | ||||||
|  |             for this_future in future_to_url: | ||||||
|  |                 this_future.add_done_callback(functools.partial(increment_progressbar, progressbar)) | ||||||
| 
 | 
 | ||||||
|         for future in as_completed(future_to_url): |         for future in as_completed(future_to_url): | ||||||
|             imdb_data = future.result() |             imdb_data = future.result() | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Sarah
						Sarah