-
Notifications
You must be signed in to change notification settings - Fork 3
/
runFTSE250.py
174 lines (149 loc) · 5.46 KB
/
runFTSE250.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
171
172
173
174
from src.mvc.controllers import (
GetIchimokuCloudDataFTSE250,
GetIchimokuCloudDataFTSE250Aggregator,
GetIchimokuCloudDataFTSE250MultiTFMerger,
GetIchimokuTKxDataFTSE250,
GetIchimokuTKxDataFTSE250Aggregator,
GetIchimokuTKxDataFTSE250MultiTFMerger,
GetSymbolFTSE250,
GetDataFTSE250,
GetIchimokuKijunDataFTSE250,
GetIchimokuKijunDataFTSE250Aggregator,
GetKickerDataFTSE250,
GetKickerDataFTSE250Aggregator,
GetIchimokuSumCloudTKxDataFTSE250MultiTFMerger,
)
from datetime import datetime
fetch_symbols_latest_FTSE250 = True
fetch_FTSE250_1H = True
fetch_FTSE250_D = True
fetch_FTSE250_W = True
fetch_FTSE250_M = True
run_Multi_TimeFrame_Merger_FTSE250 = 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_FTSE250=fetch_symbols_latest_FTSE250,
fetch_FTSE250_1H=fetch_FTSE250_1H,
fetch_FTSE250_D=fetch_FTSE250_D,
fetch_FTSE250_W=fetch_FTSE250_W,
fetch_FTSE250_M=fetch_FTSE250_M,
fetch_kijun_analysis=fetch_kijun_analysis,
fetch_Kicker_use_datetime_format=fetch_Kicker_use_datetime_format,
run_Multi_TimeFrame_Merger_FTSE250=run_Multi_TimeFrame_Merger_FTSE250,
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")
# ---------------- FTSE 250 ----------------
# 1. Grab latest symbols
_getSymbolFTSE250 = GetSymbolFTSE250
_getSymbolFTSE250.main(fetch_symbols_latest_FTSE250)
# 2. Download latest OHLC data for each symbol
_getDataFTSE250 = GetDataFTSE250
_getDataFTSE250.main(
fetch_FTSE250_1H, fetch_FTSE250_D, fetch_FTSE250_W, fetch_FTSE250_M
)
# 3. Produce Ichimoku Cloud data for each symbol
_getIchimokuCloudDataFTSE250 = GetIchimokuCloudDataFTSE250
_getIchimokuCloudDataFTSE250.main(
fetch_FTSE250_1H, fetch_FTSE250_D, fetch_FTSE250_W, fetch_FTSE250_M
)
# 3.1 Combine latest cloud signals of all symbols into one spreadsheet
_getIchimokuCloudDataFTSE250Aggregator = (
GetIchimokuCloudDataFTSE250Aggregator
)
_getIchimokuCloudDataFTSE250Aggregator.main(
fetch_FTSE250_1H, fetch_FTSE250_D, fetch_FTSE250_W, fetch_FTSE250_M
)
# 3.2 Merge Multi Time Frame Cloud signals
_getIchimokuCloudDataFTSE250MultiTFMerger = (
GetIchimokuCloudDataFTSE250MultiTFMerger
)
_getIchimokuCloudDataFTSE250MultiTFMerger.main(
run_Multi_TimeFrame_Merger_FTSE250
)
# 3.3 Produce Ichimoku TK Cross data
_gtIchimokuKijunDataFTSE250 = GetIchimokuTKxDataFTSE250
_gtIchimokuKijunDataFTSE250.main(
fetch_FTSE250_1H, fetch_FTSE250_D, fetch_FTSE250_W, fetch_FTSE250_M
)
# 3.4 Combine latest TK Cross signals from all symbols into one spreadsheet
_getIchimokuTKxDataFTSE250Aggregator = GetIchimokuTKxDataFTSE250Aggregator
_getIchimokuTKxDataFTSE250Aggregator.main(
fetch_FTSE250_1H, fetch_FTSE250_D, fetch_FTSE250_W, fetch_FTSE250_M
)
# 3.5 Merge Multi Time Frame TKx signals
_getIchimokuTKxDataFTSE250MultiTFMerger = (
GetIchimokuTKxDataFTSE250MultiTFMerger
)
_getIchimokuTKxDataFTSE250MultiTFMerger.main(
run_Multi_TimeFrame_Merger_FTSE250
)
# 3.6 Merge Multi Time Frame Cloud and TKx Sum signals
_getIchimokuSumCloudTKxDataFTSE250MultiTFMerger = (
GetIchimokuSumCloudTKxDataFTSE250MultiTFMerger
)
_getIchimokuSumCloudTKxDataFTSE250MultiTFMerger.main(
run_Multi_TimeFrame_Merger_FTSE250
)
# 4. Produce Kijun data
_getIchimokuKijunDataFTSE250 = GetIchimokuKijunDataFTSE250
_getIchimokuKijunDataFTSE250.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
_getIchimokuKijunDataFTSE250Aggregator = (
GetIchimokuKijunDataFTSE250Aggregator
)
_getIchimokuKijunDataFTSE250Aggregator.main(
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
fetch_kijun_analysis,
)
if fetch_kicker:
# 5. Produce Kicker data
_getKickerDataFTSE250 = GetKickerDataFTSE250
_getKickerDataFTSE250.main(
fetch_Kicker_use_datetime_format,
fetch_FTSE250_D,
fetch_FTSE250_W,
fetch_FTSE250_M,
)
# 5.1 Combine latest Kicker signals from all symbols into one spreadsheet
_getKickerDataFTSE250Aggregator = GetKickerDataFTSE250Aggregator
_getKickerDataFTSE250Aggregator.main(
fetch_Kicker_use_datetime_format,
fetch_FTSE250_D,
fetch_FTSE250_W,
fetch_FTSE250_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_FTSE250,
fetch_FTSE250_1H,
fetch_FTSE250_D,
fetch_FTSE250_W,
fetch_FTSE250_M,
fetch_kijun_analysis,
fetch_Kicker_use_datetime_format,
run_Multi_TimeFrame_Merger_FTSE250,
fetch_kicker,
)