forked from miro-ka/mosquito
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbackfill.py
103 lines (91 loc) · 3.87 KB
/
backfill.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
93
94
95
96
97
98
99
100
101
102
103
from pymongo import MongoClient, ASCENDING
from exchanges.poloniex.polo import Polo
from exchanges.bittrex.bittrexclient import BittrexClient
from termcolor import colored
import configargparse
import time
def main(args):
"""
Usage:
1) Loads and stores data mongodb for specific currency and specific days (from now)
backfill --currency[] --days[]
2) Loads data for all currently supported currencies for specific days (from now)
backfill --all --days[]
"""
day_constant = 86400
# Parse config
db = args.db
port = int(args.db_port)
url = args.db_url
exchange_name = args.exchange
# Init DB
client = MongoClient(url, port)
db = client[db]
ticker = db.ticker
db.ticker.create_index([('id', ASCENDING)], unique=True)
# Init exchange
if exchange_name == 'polo':
exchange = Polo()
elif exchange_name == 'bittrex':
exchange = BittrexClient()
else:
print('Invalid exchange name in config.ini file!')
return
# Get list of all currencies
all_pairs = exchange.get_pairs()
if args.all:
pairs = all_pairs
elif args.pairs is not None:
tmp_pairs = args.pairs.replace(" ", "").split(',')
pairs = []
# Handle * suffix pairs
for pair in tmp_pairs:
if '*' in pair:
prefix = pair.replace('*', '')
pairs_list = [p for p in all_pairs if prefix in p]
pairs.extend(pairs_list)
# remove duplicates
pairs = list(set(pairs))
else:
pairs.append(pair)
# Get the candlestick data
epoch_now = int(time.time())
for pair in pairs:
for day in reversed(range(1, int(args.days)+1)):
epoch_from = epoch_now - (day_constant*day)
epoch_to = epoch_now if day == 1 else epoch_now - (day_constant * (day-1))
print('Getting currency data: ' + pair + ', days left: ' + str(day), end='')
candles = exchange.get_candles(pair, epoch_from, epoch_to, 300) # by default 5 minutes candles (minimum)
print(' (got total candles: ' + str(len(candles)) + ')')
for candle in candles:
if candle['date'] == 0:
print(colored('Found nothing for pair: ' + pair, 'yellow'))
continue
# Convert strings to number (float or int)
for key, value in candle.items():
if key == 'date':
candle[key] = int(value)
else:
candle[key] = float(value)
new_db_item = candle.copy()
# Add identifier
new_db_item['exchange'] = exchange_name
new_db_item['pair'] = pair
unique_id = exchange_name + '-' + pair + '-' + str(candle['date'])
new_db_item['id'] = unique_id
# Store to DB
ticker.update_one({'id': unique_id}, {'$set': new_db_item}, upsert=True)
# print('Backfill data import done..')
if __name__ == "__main__":
arg_parser = configargparse.get_argument_parser()
arg_parser.add('-c', '--config', is_config_file=True, help='config file path', default='mosquito.ini')
arg_parser.add('--pairs', help='Pairs to backfill. For ex. [BTC_ETH, BTC_* (to get all BTC_* prefixed pairs]')
arg_parser.add("--all", help='Backfill data for ALL currencies', action='store_true')
arg_parser.add("--days", help="Number of days to backfill", required=True, type=int, default=1)
arg_parser.add('--exchange', help='Exchange')
arg_parser.add('--db_url', help='Mongo db url')
arg_parser.add('--db_port', help='Mongo db port')
arg_parser.add('--db', help='Mongo db')
arg_parser.add('-v', '--verbosity', help='Verbosity', action='store_true')
options = arg_parser.parse_known_args()[0]
main(options)