removed last comment and added main() function
This commit is contained in:
parent
9d9d72e8d0
commit
3b2c36f6ad
46
posh.py
46
posh.py
@ -78,44 +78,42 @@ def new_sold_list_builder(i):
|
||||
return new_sold_prices
|
||||
|
||||
|
||||
search_query = str(input('Title Search: '))
|
||||
def main():
|
||||
|
||||
start = time.time()
|
||||
search_query = str(input('Title Search: '))
|
||||
|
||||
page_list = list(range(1, 2))
|
||||
all_sold_list = []
|
||||
new_sold_list = []
|
||||
start = time.time()
|
||||
|
||||
with concurrent.futures.ThreadPoolExecutor() as executor:
|
||||
page_list = list(range(1, 2))
|
||||
all_sold_list = []
|
||||
new_sold_list = []
|
||||
|
||||
with concurrent.futures.ThreadPoolExecutor() as executor:
|
||||
for future in executor.map(all_sold_list_builder, page_list):
|
||||
all_sold_list.extend(future)
|
||||
|
||||
with concurrent.futures.ThreadPoolExecutor() as executor:
|
||||
with concurrent.futures.ThreadPoolExecutor() as executor:
|
||||
for future in executor.map(new_sold_list_builder, page_list):
|
||||
new_sold_list.extend(future)# if you can pull the nwt price simultaneously with used then you won't have to use this
|
||||
|
||||
|
||||
for element in new_sold_list:
|
||||
for element in new_sold_list:
|
||||
all_sold_list.remove(element)
|
||||
used_sold_list = all_sold_list
|
||||
used_sold_list = all_sold_list
|
||||
|
||||
average_used_sold_price = '$' + str(round(np.mean(used_sold_list), 2))
|
||||
average_new_sold_price = '$' + str(round(np.mean(new_sold_list), 2))
|
||||
average_used_sold_price = '$' + str(round(np.mean(used_sold_list), 2))
|
||||
average_new_sold_price = '$' + str(round(np.mean(new_sold_list), 2))
|
||||
|
||||
used_sold_results = str(len(used_sold_list)) + ' Used Results'
|
||||
new_sold_results = str(len(new_sold_list)) + ' NWT Results'
|
||||
total_results = str(len(used_sold_list) + len(new_sold_list)) + ' Total Results'
|
||||
used_sold_results = str(len(used_sold_list)) + ' Used Results'
|
||||
new_sold_results = str(len(new_sold_list)) + ' NWT Results'
|
||||
total_results = str(len(used_sold_list) + len(new_sold_list)) + ' Total Results'
|
||||
|
||||
end = time.time()
|
||||
end = time.time()
|
||||
|
||||
print(end - start, 'seconds')
|
||||
print(end - start, 'seconds')
|
||||
|
||||
print('Average Used Sold Price', average_used_sold_price, used_sold_results)
|
||||
print('Average New Sold Price', average_new_sold_price, new_sold_results)
|
||||
print(total_results)
|
||||
print('Average Used Sold Price', average_used_sold_price, used_sold_results)
|
||||
print('Average New Sold Price', average_new_sold_price, new_sold_results)
|
||||
print(total_results)
|
||||
|
||||
'''There has to be a way to determine the number of pages present prior to making far too many requests. Look at network in the element inspector to see if there might be some kind of id that gives away the page type. some responses might be different other than in their html code. Otherwise you can maybe determine a threshold payload; so if a payload is smaller than so many kb then you can block it.
|
||||
|
||||
This will be significant to speeding up your programming. If you keep having to make requests to 20 pages and wait on the results it may not be that much faster than just using pms.py, but if you can limit it only to what is absolutely required then that would be best. Also You nee to see if multiprocessing would be best for crunching all the prices in the lists.
|
||||
|
||||
Another workaround is by just doing a loop but in chunks of more than one page. so make your first list 1-4, send that to the multithreadpool, then take the next 4 pages and do the same thing until you get no listings found at which point you will stop the while loop. and you could even have the multithreader use separate page lists for the new and all . '''
|
||||
main()
|
||||
|
Loading…
Reference in New Issue
Block a user