-
Notifications
You must be signed in to change notification settings - Fork 177
/
Copy pathPython_script_example_PyTrader.py
242 lines (196 loc) · 8.26 KB
/
Python_script_example_PyTrader.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
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
"""
PyTrader api - script example for easy connection with Metatrader4 EA & Metatrader5 EA
This is an example file with all calling functions to metatrader terminal and get it back to your script
For closing/deleting trades, ticket numbers must be known.
Also opening orders openprice, sl and tp must be appropriate
"""
import socket, numpy as np
import pandas as pd
import configparser
from datetime import datetime
import pytz
from utils.Pytrader_API import Pytrader_API
## Intialization
## documentation reference 1
MT = Pytrader_API()
# There are diffferent ways to connect to the MT connector.
# Option #1: if the EA is on same computer
# you need a list with universal instrument names(you use in the python application) and the broker
# specific instrument names.
# by this you can make your python application broker independent
# Optional way of building the list
brokerInstrumentsLookup = {'EURUSD':'EURUSD', 'GBPNZD':'GBPNZD', 'GOLD':'XAUUSD', 'DAX':'GER30'}
# Option #2: a different way is by working with a configuration file shown below.
# example is added
# example script for reading the configuration file and building the list
def config_instruments(config, section):
dict1 = {}
options = config.options(section)
for option in options:
try:
option = option.upper()
dict1[option] = config.get(section, option)
if dict1[option] == -1:
print("skip: %s" % option)
except:
print("exception on %s!" % option)
dict1[option] = None
return dict1
# Read in config
CONFIG_FILE= "Instrument.conf"
config = configparser.ConfigParser()
config.read(CONFIG_FILE)
brokerInstrumentsLookup = config_instruments(config,"ICM")
## or
# brokerInstrumentsLookup = config_instruments(config,'FXPIG')
## Connection line of code
## (documentation reference 2)
## Connected: boolean
Connected = MT.Connect(server='127.0.0.1', port=11111, instrument_lookup=brokerInstrumentsLookup)
## 2, EA is on other computer in same local network
## (documentation reference 2)
## ok: boolean
#ok = MT.Connect(server='192.168.0.103', port=22222, instrument_lookup=brokerInstrumentsLookup)
## setting the debug characteristic of the MT connector to false, default is false
## this will give extra information in case of troubles/feedback
MT.debug = False
## IsAlive - you can always check if the connection is still OK
## IsAlive = boolean
IsAlive = MT.connected
print(IsAlive)
## check connection, renew connection check
## (documentation reference 3)
## KeepAliveCheck = boolean
KeepAliveCheck = MT.Check_connection()
## Change the time out, for retrieving long bar history or slow systems you can set an other connection time out
## (documentation reference 4)
MT.Set_timeout(timeout_in_seconds=120)
## Retrieve broker server time
## (documentation reference 5)
## ServerTime = datetime
ServerTime = MT.Get_broker_server_time()
print(ServerTime)
print('')
## Get static account information
## (documentation reference 6)
## StaticInfo = dictionairy
StaticInfo = MT.Get_static_account_info()
for prop in StaticInfo:
print(" {}={}".format(prop, result[prop]))
print('')
## Get dynamic account information
## (documentation reference 7)
## DynamicInfo = dictionairy
DynamicInfo = MT.Get_dynamic_account_info()
for prop in DynamicInfo:
print(" {}={}".format(prop, result[prop]))
print('')
## Get instrument information
## (documentation reference 8)
## InstrumentInfo = dictionairy, if instrument not known at broker the value 'None' will be returned
InstrumentInfo = MT.Get_instrument_info(instrument='EURUSD')
for prop in InstrumentInfo:
print(" {}={}".format(prop, result[prop]))
print('')
## Get last tick information
## (documentation reference 9)
## LastTick = dictionary
LastTick = MT.Get_last_tick_info(instrument='GBPNZD')
print('')
for prop in LastTicket:
print(" {}={}".format(prop, result[prop]))
print('')
## For Live/Paper trading
## The above function can be used for live streaming of data
## Get actual bar information
## (documentation reference 10)
## ActualBar = dictionary
ActualBar = MT.Get_actual_bar_info(instrument='EURUSD', timeframe=MT.Get_timeframe_value('H4'))
for prop in ActualBar:
print(" {}={}".format(prop, result[prop]))
print('')
## For Live/Paper trading
## The above function can be used for live streaming of data
## Get last x ticks from now, working for MT5 Only.
## if MT terminal does not have this in history it may take some time to download
## MT terminal needs first to retrieve from broker
## the max amount of ticks is broker dependent
## socket time out is set to 60 seconds as default, if needed change time out
## (documentation reference 11)
## LastTicks = data frame
LastTicks = MT.Get_last_x_ticks_from_now(instrument='EURUSD', nbrofticks=500)
ticks = pd.DataFrame(LastTickets)
print(ticks.head())
print('')
## Get last x bars from MT terminal
## if MT terminal does not have this in history it may take some time to download
## MT terminal needs first to retrieve from broker
## the max amount of bars is broker dependent
## socket time out is set to 60 seconds
## (documentation reference 12)
## LastBars = data frame
LastBars = MT.Get_last_x_bars_from_now(instrument='EURUSD', timeframe=MT.Get_timeframe_value('M1'), nbrofbars=1000)
## Open a new order (market or pending)
## (documentation reference 13)
## Send a new order, in this case pending order :
## NewOrder = int, order ticket
NewOrder = MT.Open_order(instrument='EURUSD', ordertype='buy_stop', volume=0.01, openprice=1.136, slippage=10, magicnumber=2000, stoploss=1.12, takeprofit=1.14, comment='Test')
if (NewOrder == -1): # opening order failed
print(MT.order_error)
print(MT.order_return_message)
## Send a new order, in this case market order
NewOrder = MT.Open_order(instrument='EURUSD', ordertype='buy', volume=0.01, openprice=0.0, slippage=10, magicnumber=2000, stoploss=0.0, takeprofit=0.0, comment='Test')
if (NewOrder == -1): # opening order failed
print(MT.order_error)
print(MT.order_return)
## set/change stopploss and takeprofit for position
## (documentation reference 14)
## ChangePosition = boolean
ChangePosition = MT.Set_sl_and_tp_for_position(ticket=53136604, stoploss=0.0, takeprofit=1.11001)
if (ChangePosition == False): # setting sl/tp failed for position
print(MT.order_error)
print(MT.order_return_message)
## Set stopploss and takeprofit for order (pendings)
## (documentation reference 15)
## ChangeOrder = boolean
ChangeOrder = MT.Set_sl_and_tp_for_order(ticket=53136804, stoploss=0.0, takeprofit=1.12001)
if (changeOrder == False): # setting sl/tp failed for order
print(MT.order_error)
print(MT.order_return_message)
## Get all orders (pendings)
## (documentation reference 16)
## AllOrders = data frame
AllOrders = MT.Get_all_orders()
print('')
print(allOrders)
## Get all (open) positions
## (documentation reference 17)
## AllPositions = data frame
AllPositions = MT.Get_all_open_positions()
print('')
print(allPositions)
## Get all closed position in a specified time period
## (documentation reference 18)
## AllClosedPositions = data frame
print('')
print('closed positions')
timezone = pytz.timezone("Etc/UTC")
AllClosedPositions = MT.Get_all_closed_positions(date_from=datetime(2020, 3, 3, tzinfo=timezone), date_to=datetime.now())
print(AllClosedPositions)
## Close position by ticket
## (documentation reference 19)
## ClosePosition = boolean
ClosePosition = MT.Close_position_by_ticket(ticket=597318718)
## close position partly
## documentation reference 20
PartialClose = MT.Close_position_partial_by_ticket(ticket=367014000, volume_to_close=0.01)
if (PartialClose == False):
print(MT.order_return_message)
## Delete order by ticket
## (documentation reference 20)
## DeleteOrder = boolean
DeleteOrder = MT.Delete_order_by_ticket(ticket=49988037)
## result check
if (DeleteOrder == False):
print(MT.order_error)
print(MT.order_return_message)