-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathscrapeBuff.py
92 lines (80 loc) · 3.49 KB
/
scrapeBuff.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#Note: Buff163 does not release its statistics on rate limits, but upon testing, a total of 3 scrapers at a time works best
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.support.ui import Select
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import NoSuchElementException
from executeOrder import purchase
import json
import time
import re
import os
import threading
import pickle
import sys
# The notifier function
def notify(title, text):
os.system("""
osascript -e 'display notification "{}" with title "{}"'
""".format(text, title))
def obtainItems(request, driver, maximumFloat): # obtain list of 10 items wear values and prices for the links found in json file. Returns true if match is found
driver.get(request) # driver configs
cookies = pickle.load(open("cookies.pkl", "rb")) # enable cookies
for cookie in cookies:
driver.add_cookie(cookie)
isNamed = True
try:
print(driver.find_element(By.XPATH, '/html/body/div[7]/div/div[1]/div[2]/div[1]/h1').text,':\n')
except NoSuchElementException:
print('pass')
isNamed = False
for i in range(10):
try:
wear = driver.find_element(By.XPATH, '/html/body/div[6]/div/div[7]/table/tbody/tr[{}]/td[3]/div/div[1]/div[1]'.format(i+2))
price = driver.find_element(By.XPATH, '/html/body/div[6]/div/div[7]/table/tbody/tr[{}]/td[5]/div[1]/strong'.format(i+2)) #consistent html behavior across different item links for CS:GO
except NoSuchElementException:
print("could not locate item")
continue
weartext = float(''.join(c for c in wear.text if c.isdigit() or c=='.'))
print("Listing {}".format(i+1))
print(price.text)
print("Float:", weartext,"\n")
print(threading.active_count())
if weartext < maximumFloat:
notify("Buff Scraper", "An item has been found that matches your criteria: {} {} \n{}"
.format(driver.find_element(By.XPATH, '/html/body/div[7]/div/div[1]/div[2]/div[1]/h1').text if isNamed else 'Unknown Name', "Listing {}".format(i+1), "Float: {}".format(weartext)))
purchase(driver, i)
driver.quit
class ScrapeThread(threading.Thread):
def __init__(self, scrapernumber, maximumFloat):
threading.Thread.__init__(self)
self.scrapernumber = scrapernumber
self.maximumFloat = maximumFloat
def run(self):
scrapeCount = 'scraper' + str(self.scrapernumber)
while True:
for link in data[scrapeCount]:
options = webdriver.ChromeOptions()
options.add_argument('--headless')
driver = webdriver.Chrome(options=options)
obtainItems(link, driver, self.maximumFloat)
def scrape(firstScraper, lastScraper, maximumFloat):
threads = []
for scrapeNum in range(firstScraper, lastScraper+1):
t = ScrapeThread(scrapeNum, maximumFloat)
t.start()
threads.append(t)
for t in threads:
t.join()
f = open('./buff.json')
data = json.load(f)
if len(sys.argv) != 4:
print('Please enter the correct number of arguments')
pass
else:
scrape(int(sys.argv[1]), int(sys.argv[2]), float(sys.argv[3]))
# Note: if you want an example of a function run, uncomment this:
# scrape(1, 4, 0.10)
# add readme.md