-
Notifications
You must be signed in to change notification settings - Fork 3
/
runFutures.py
170 lines (147 loc) · 5.43 KB
/
runFutures.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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
from src.mvc.controllers import (
GetIchimokuCloudDataFutures,
GetIchimokuCloudDataFuturesAggregator,
GetIchimokuCloudDataFuturesMultiTFMerger,
GetIchimokuTKxDataFutures,
GetIchimokuTKxDataFuturesAggregator,
GetIchimokuTKxDataFuturesMultiTFMerger,
GetSymbolFutures,
GetDataFutures,
GetIchimokuKijunDataFutures,
GetIchimokuKijunDataFuturesAggregator,
GetKickerDataFutures,
GetKickerDataFuturesAggregator,
GetIchimokuSumCloudTKxDataFuturesMultiTFMerger,
)
from datetime import datetime
fetch_symbols_latest_Futures = True
fetch_Futures_1H = True
fetch_Futures_D = True
fetch_Futures_W = True
fetch_Futures_M = True
run_Multi_TimeFrame_Merger_Futures = True
fetch_kijun_analysis = False
fetch_kicker = False
# Use "Datetime" for Yahoo intraday data,
# "Date" for D, W, M data.
# Use "Datetime" for all Oanda data.
fetch_Kicker_use_datetime_format = False
def main(
fetch_symbols_latest_Futures=fetch_symbols_latest_Futures,
fetch_Futures_1H=fetch_Futures_1H,
fetch_Futures_D=fetch_Futures_D,
fetch_Futures_W=fetch_Futures_W,
fetch_Futures_M=fetch_Futures_M,
fetch_kijun_analysis=fetch_kijun_analysis,
fetch_Kicker_use_datetime_format=fetch_Kicker_use_datetime_format,
run_Multi_TimeFrame_Merger_Futures=run_Multi_TimeFrame_Merger_Futures,
fetch_kicker=fetch_kicker,
):
# Stop script being auto-run by Replit or Gitpod
# return
time_start = datetime.now()
print("Task begins at:", time_start.strftime("%Y-%m-%d %H:%M:%S"), "\n")
# ---------------- Futures ----------------
# 1. Grab latest symbols
_getSymbolFutures = GetSymbolFutures
_getSymbolFutures.main(fetch_symbols_latest_Futures)
# 2. Download latest OHLC data for each symbol
_getDataFutures = GetDataFutures
_getDataFutures.main(
fetch_Futures_1H, fetch_Futures_D, fetch_Futures_W, fetch_Futures_M
)
# 3. Produce Ichimoku Cloud data for each symbol
_getIchimokuCloudDataFutures = GetIchimokuCloudDataFutures
_getIchimokuCloudDataFutures.main(
fetch_Futures_1H, fetch_Futures_D, fetch_Futures_W, fetch_Futures_M
)
# 3.1 Combine latest cloud signals of all symbols into one spreadsheet
_getIchimokuDataFuturesAggregator = GetIchimokuCloudDataFuturesAggregator
_getIchimokuDataFuturesAggregator.main(
fetch_Futures_1H, fetch_Futures_D, fetch_Futures_W, fetch_Futures_M
)
# 3.2 Merge Multi Time Frame Cloud signals
_getIchimokuCloudDataFuturesMultiTFMerger = (
GetIchimokuCloudDataFuturesMultiTFMerger
)
_getIchimokuCloudDataFuturesMultiTFMerger.main(
run_Multi_TimeFrame_Merger_Futures
)
# 3.3 Produce Ichimoku TK Cross data
_getIchimokuTKxDataFutures = GetIchimokuTKxDataFutures
_getIchimokuTKxDataFutures.main(
fetch_Futures_1H, fetch_Futures_D, fetch_Futures_W, fetch_Futures_M
)
# 3.4 Combine latest TK Cross signals from all symbols into one spreadsheet
_getIchimokuTKxDataFuturesAggregator = GetIchimokuTKxDataFuturesAggregator
_getIchimokuTKxDataFuturesAggregator.main(
fetch_Futures_1H, fetch_Futures_D, fetch_Futures_W, fetch_Futures_M
)
# 3.5 Merge Multi Time Frame TKx signals
_getIchimokuTKxDataFuturesMultiTFMerger = (
GetIchimokuTKxDataFuturesMultiTFMerger
)
_getIchimokuTKxDataFuturesMultiTFMerger.main(
run_Multi_TimeFrame_Merger_Futures
)
# 3.6 Merge Multi Time Frame Cloud and TKx Sum signals
_getIchimokuSumCloudTKxDataFuturesMultiTFMerger = (
GetIchimokuSumCloudTKxDataFuturesMultiTFMerger
)
_getIchimokuSumCloudTKxDataFuturesMultiTFMerger.main(
run_Multi_TimeFrame_Merger_Futures
)
# 4. Produce Kijun data
_getIchimokuKijunDataFutures = GetIchimokuKijunDataFutures
_getIchimokuKijunDataFutures.main(
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
)
# 4.1 Combine latest Kijun signals from all symbols into one spreadsheet
_getIchimokuKijunDataFuturesAggregator = (
GetIchimokuKijunDataFuturesAggregator
)
_getIchimokuKijunDataFuturesAggregator.main(
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
)
if fetch_kicker:
# 5. Produce Kicker data
_getKickerDataFutures = GetKickerDataFutures
_getKickerDataFutures.main(
fetch_Kicker_use_datetime_format,
fetch_Futures_D,
fetch_Futures_W,
fetch_Futures_M,
)
# 5.1 Combine latest Kicker signals from all symbols into one spreadsheet
_getKickerDataFuturesAggregator = GetKickerDataFuturesAggregator
_getKickerDataFuturesAggregator.main(
fetch_Kicker_use_datetime_format,
fetch_Futures_D,
fetch_Futures_W,
fetch_Futures_M,
)
# calculate time elapsed
time_finish = datetime.now()
time_elapsed = time_finish - time_start
time_finish_formatted = time_finish.strftime("%Y-%m-%d %H:%M:%S")
print(
f"\nTasks completed at {time_finish_formatted} (Time elapsed: {time_elapsed})",
)
if __name__ == "__main__":
main(
fetch_symbols_latest_Futures,
fetch_Futures_1H,
fetch_Futures_D,
fetch_Futures_W,
fetch_Futures_M,
fetch_kijun_analysis,
fetch_Kicker_use_datetime_format,
run_Multi_TimeFrame_Merger_Futures,
fetch_kicker,
)