forked from IrakliXYZ/ARBOT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuilder.py
120 lines (103 loc) · 6.06 KB
/
builder.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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# This file builds the tables and dictionaries (FTX)
# Import the modules
import os, datetime
# Import sibling modules
import calculator, FTX_sourcer
# Variables
maker_fee = float(os.getenv('FTX_MAKER_FEE'))
taker_fee = float(os.getenv('FTX_TAKER_FEE'))
# Table maker
def table(values):
first = values[0]
keys = list(first.keys()) if isinstance(first, dict) else range(0, len(first))
widths = [max([len(str(v[k])) for v in values]) for k in keys]
string = ' | '.join(['{:<' + str(w) + '}' for w in widths])
return "\n".join([string.format(*[str(v[k]) for k in keys]) for v in values])
# Generate only list dictionary
def generate_list(pair, lvrg):
amnt = 10000.00
pair_funding_rate = FTX_sourcer.funding_rates(pair + '-PERP')
pair_funding_rate_h = float(pair_funding_rate['funding h'])
pair_funding_rate_d = float(pair_funding_rate['funding d'])
pair_funding_rate_w = float(pair_funding_rate['funding w'])
pair_funding_rate_m = float(pair_funding_rate['funding m'])
pair_funding_rate_y = float(pair_funding_rate['funding y'])
calculated_spread = float(calculator.difference(FTX_sourcer.PERP(pair + '-PERP')['PERP_price'], FTX_sourcer.USD(pair + '/USD')['USD_price']))
# data.append({
# datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
# calculated_spread,
# pair_funding_rate_h * 100,
# pair_funding_rate_d * 100,
# calculator.profit(amnt, pair_funding_rate_d, maker_fee, calculated_spread, lvrg),
# calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_d, maker_fee, calculated_spread, lvrg), amnt),
# pair_funding_rate_w * 100,
# calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg),
# calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg), amnt),
# pair_funding_rate_m * 100,
# calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg),
# calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg), amnt),
# pair_funding_rate_y * 100, calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg),
# calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg), amnt)
# })
# return data
# return {
# # 'pair': pair,
# # 'amount': amnt,
# # 'leverage': lvrg,
# 'date_time': datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
# 'spread %': calculated_spread,
# 'funding_rate_h': pair_funding_rate_h * 100,
# 'funding_rate_d': pair_funding_rate_d * 100,
# 'profit_d': calculator.profit(amnt, pair_funding_rate_d, maker_fee, calculated_spread, lvrg),
# 'effective_rate_d': calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_d, maker_fee, calculated_spread, lvrg), amnt),
# 'funding_rate_w': pair_funding_rate_w * 100,
# 'profit_w': calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg),
# 'effective_rate_w': calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg), amnt),
# 'funding_rate_m': pair_funding_rate_m * 100,
# 'profit_m': calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg),
# 'effective_rate_m': calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg), amnt),
# 'funding_rate_y': pair_funding_rate_y * 100,
# 'profit_y': calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg),
# 'effective_rate_y': calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg), amnt)
# }
return [
datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
calculated_spread * 100,
pair_funding_rate_h * 100,
pair_funding_rate_w * 100,
calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg),
calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_w, maker_fee, calculated_spread, lvrg), amnt),
pair_funding_rate_m * 100,
calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg),
calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_m, maker_fee, calculated_spread, lvrg), amnt),
pair_funding_rate_y * 100,
calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg),
calculator.effective_rate_calculator(calculator.profit(amnt, pair_funding_rate_y, maker_fee, calculated_spread, lvrg), amnt)
]
# print(generate_table(10000, 3))
# Generate a printable table of all available pairs with a header
def generate_table(amnt, lvrg, period):
available_FTX = FTX_sourcer.available_FTX
data = []
# Make a data header
data.append({
'pair': 'Name',
'funding_rate': 'Funding %/' + period,
'spread': 'Spread %',
'profit': 'Profits $',
'effective_rate': 'Effective Rate %/' + period
})
# Loop through available coins and append to the list
for i in available_FTX:
pair_funding_rate = float(FTX_sourcer.funding_rates(i + '-PERP')['funding ' + period])
calculated_spread = float(calculator.difference(FTX_sourcer.PERP(i + '-PERP')['PERP_price'], FTX_sourcer.USD(i + '/USD')['USD_price']))
calculated_profit = calculator.profit(amnt, pair_funding_rate, taker_fee, calculated_spread, lvrg)
data.append({
'pair': i,
'funding_rate': "{:.4f}".format(pair_funding_rate * 100),
'spread': "{:.4f}".format(calculated_spread * 100),
'profit': "{:.2f}".format(calculated_profit),
'effective_rate': "{:.2f}".format(calculator.effective_rate_calculator(calculated_profit, amnt))
})
return table(data)
# print(generate_table())