API функции для OANDA - Python

Узнай цену своей работы

Формулировка задачи:

Может будет нужно тем кто занимается разработкой торговых роботов. Если кто увидит серьезные огрехи, буду рад если поправите. Python изучаю только пол года. Специально для этой темы.
Листинг программы
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. import openpyxl
  4. import httplib
  5. import urllib
  6. import urllib2
  7. import json
  8. import datetime
  9. from datetime import datetime, timedelta, date, time
  10. import os
  11. import msvcrt
  12. import time
  13. import shutil # копирование
  14. import ssl
  15. import requests
  16. import sys
  17. ssl._create_default_https_context = ssl._create_unverified_context # убирает ошибку [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:590)
  18. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв–’в–“в–‘в–€в•ђв–Њв–* в–ђв‰Ўв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  19. url = "api-fxtrade.oanda.com"
  20. access_token = "Bearer 099935ef71b8203fxxxxxxxxxxxxxxxxdbd7b30dbdb3019d673671020752f"
  21. headers = {'Authorization': access_token, "Content-Type": "application/x-www-form-urlencoded"}
  22. accounts = []
  23. account_id = ""
  24. instrument = ""
  25. sentSMS = True
  26. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  27. print u'в–€' * 11 + ' Oanda API script started ' + u'в–€' * 11
  28. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  29. mypairs = ['AUD_HKD', 'AUD_JPY', 'AUD_USD', 'CAD_HKD', 'CAD_JPY', 'CHF_JPY', 'EUR_AUD', 'EUR_GBP', 'EUR_HKD', 'EUR_JPY',
  30. 'EUR_USD', 'GBP_AUD', 'GBP_CAD', 'GBP_CHF', 'GBP_HKD', 'GBP_JPY', 'GBP_NZD', 'GBP_USD', 'NZD_HKD', 'NZD_JPY',
  31. 'NZD_USD', 'USD_CAD', 'USD_JPY']
  32. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  33. data_pair = dict((x, [0] * 2) for x in mypairs) # генерация словаря
  34. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  35. p_prices = {'USD': {'USD': 1.00000,
  36. 'CAD': 0.76620,
  37. 'CHF': 1.01360,
  38. 'JPY': 0.93000,
  39. 'AUD': 0.74820,
  40. 'GBP': 1.31650,
  41. 'NZD': 0.70230,
  42. 'EUR': 1.10190,
  43. 'HKD': 0.12900},
  44. 'CHF': {'CHF': 1.00000,
  45. 'CAD': 0.76090,
  46. 'USD': 0.98230,
  47. 'JPY': 0.93000,
  48. 'AUD': 0.74980,
  49. 'GBP': 1.31030,
  50. 'NZD': 0.70240,
  51. 'EUR': 1.10190,
  52. 'HKD': 0.12710}}
  53. #в”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђв”Ђ
  54.  
  55. def get_currency_rates(currency):
  56. params = urllib.urlencode({'number': '1'})
  57. headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0)'}
  58. dictfull = False
  59. while True:
  60. try:
  61. print 'в•ђ' * 30
  62. print 'GETTING CURRENCY RATES for ' + currency
  63. print 'в•ђ' * 30
  64. for key in sorted(p_prices[currency]):
  65. pairforprice = key + '-' + currency
  66. time.sleep(0.5)
  67. url = 'https://www.mataf.net/ru/currency/converter-' + pairforprice
  68. request = urllib2.Request(url, params, headers)
  69. resptext = urllib2.urlopen(request).read()
  70. line = resptext
  71. line = line.strip()
  72. linekurs = line.find('<title>')
  73. startkurs = line.find('=', linekurs)
  74. endkurs = line.find(')</title>', linekurs)
  75. kurs = float(line[startkurs + 1:endkurs])
  76. if 'JPY' in key:
  77. kurs *= 100
  78. kurs = "%.4f" % kurs
  79. print pairforprice, kurs
  80. p_prices[currency][key] = float(kurs)
  81. dictfull = True
  82. except Exception as e:
  83. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  84. if dictfull:
  85. return datetime.utcnow()
  86. else:
  87. print 'CURRENCY RATES DATA PROBLEM!'
  88. time.sleep(60)
  89.  
  90. def close_position(account_id, instrument):
  91. try:
  92. time.sleep(0.5)
  93. params = urllib.urlencode({'accountId': account_id})
  94. conn = httplib.HTTPSConnection(url)
  95. conn.request("DELETE", "/v1/accounts/" + account_id + "/positions/" + instrument, params, headers)
  96. response = conn.getresponse()
  97. resptext = response.read()
  98. if response.status == 403:
  99. print instrument + ' position not closed'
  100. elif response.status == 200:
  101. print instrument + ' position closed'
  102. return response.status
  103. except Exception as e:
  104. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  105.  
  106. def get_position(account_id, instrument):
  107. try:
  108. time.sleep(1)
  109. params = urllib.urlencode({})
  110. conn = httplib.HTTPSConnection(url)
  111. # GET /v1/accounts/:account_id/positions/:instrument
  112. conn.request("GET", "/v1/accounts/" + account_id +
  113. "/positions/" + instrument, params, headers)
  114. response = conn.getresponse()
  115. resptext = response.read()
  116. return resptext
  117. except Exception as e:
  118. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  119.  
  120. def get_instrument(account_id, instrument):
  121. try:
  122. time.sleep(1)
  123. params = urllib.urlencode({})
  124. conn = httplib.HTTPSConnection(url)
  125. conn.request("GET", "/v1/instruments?accountId=" + account_id +
  126. "&instruments=" + instrument +
  127. "&fields=instrument%2CdisplayName%2Cpip%2CmarginRate%2Chalted", params, headers)
  128. response = conn.getresponse()
  129. resptext = response.read()
  130. return resptext
  131. except Exception as e:
  132. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  133.  
  134. def get_all_instrument(account_id):
  135. try:
  136. time.sleep(1)
  137. params = urllib.urlencode({})
  138. conn = httplib.HTTPSConnection(url)
  139. conn.request("GET", "/v1/instruments?accountId=" + account_id, params, headers)
  140. response = conn.getresponse()
  141. resptext = response.read()
  142. return resptext
  143. except Exception as e:
  144. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  145.  
  146. def get_price(instrument):
  147. try:
  148. time.sleep(1)
  149. params = urllib.urlencode({})
  150. conn = httplib.HTTPSConnection(url)
  151. conn.request("GET", "/v1/prices?instruments=" + instrument, params, headers)
  152. response = conn.getresponse()
  153. resptext = response.read()
  154. return resptext
  155. except Exception as e:
  156. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  157.  
  158. def get_FXdata1(instrument, granularity, start, end): # пара, таймфрейм
  159. try:
  160. time.sleep(1)
  161. # start = str(date.today()) + 'T00%3A00%3A00Z'
  162. # end = str(date.today()) + 'T03%3A00%3A00Z'
  163. conn = httplib.HTTPSConnection(url)
  164. conn.request("GET", "/v1/candles?instrument=" + instrument +
  165. "&granularity=" + granularity +
  166. "&candleFormat=" + 'midpoint' +
  167. "&dailyAlignment=" + str(0) +
  168. "&alignmentTimezone=" + 'UTC' +
  169. "&start=" + start +
  170. "&end=" + end)
  171. response = conn.getresponse()
  172. resptext = response.read()
  173. return resptext
  174. except Exception as e:
  175. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  176.  
  177. def get_FXdata2(instrument, granularity, count): # пара, таймфрейм
  178. try:
  179. time.sleep(1)
  180. conn = httplib.HTTPSConnection(url)
  181. conn.request("GET", "/v1/candles?instrument=" + instrument +
  182. "&count=" + str(count) +
  183. "&granularity=" + granularity +
  184. "&candleFormat=" + 'midpoint' +
  185. "&dailyAlignment=" + str(0) +
  186. "&alignmentTimezone=" + 'UTC')
  187. response = conn.getresponse()
  188. resptext = response.read()
  189. return resptext
  190. except Exception as e:
  191. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  192.  
  193. def send_sms(text):
  194. if sentSMS:
  195. url = "http://sms.ru/sms/send?api_id=4760338A-D9xxxxxxxxxxxxxxxx2D5C&to=79205616220&from=Forex Robot&text=" + text
  196. try:
  197. answer = requests.get(url)
  198. print "SMS sended"
  199. except Exception as e:
  200. print "SMS not sended"
  201. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  202.  
  203. def get_range(instrument, granularity, count):
  204. try:
  205. time.sleep(1)
  206. count += 1 # для незакрытой свечи
  207. data = get_FXdata2(instrument, granularity, count)
  208. data = json.loads(data)
  209. max_highMid = 0
  210. min_lowMid = 999999
  211. for key in data['candles']:
  212. if max_highMid < key[u'highMid']:
  213. max_highMid = key[u'highMid']
  214. if min_lowMid > key[u'lowMid']:
  215. min_lowMid = key[u'lowMid']
  216. return max_highMid, min_lowMid
  217. except Exception as e:
  218. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  219.  
  220. def get_avg_volatil(instrument, granularity, count):
  221. try:
  222. time.sleep(1)
  223. count += 1 # для незакрытой свечи
  224. data = get_FXdata2(instrument, granularity, count)
  225. data = json.loads(data)
  226. maxcandle = 0
  227. mincandle = 99999
  228. sumcandle = 0
  229. for key in data['candles']:
  230. if key[u'complete']:
  231. volatilcandle = (key[u'highMid'] - key[u'lowMid']) * 10000
  232. if 'JPY' in instrument:
  233. volatilcandle = volatilcandle / 100
  234. if maxcandle < volatilcandle:
  235. maxcandle = volatilcandle
  236. if mincandle > volatilcandle:
  237. mincandle = volatilcandle
  238. sumcandle += volatilcandle
  239. if count >= 4:
  240. avgvolatil = int(round((sumcandle - maxcandle - mincandle) / (count - 3)))
  241. else:
  242. avgvolatil = int(round(sumcandle / (count - 1)))
  243. return avgvolatil
  244. except Exception as e:
  245. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  246.  
  247. def get_today_volatil(instrument, granularity, count):
  248. try:
  249. time.sleep(1)
  250. count += 1 # для незакрытой свечи
  251. data = get_FXdata2(instrument, granularity, count)
  252. data = json.loads(data)
  253. max_highMid = 0
  254. min_lowMid = 999999
  255. max_body = 0
  256. min_body = 999999
  257. if 'candles' in data.keys():
  258. for key in data['candles']:
  259. if max_highMid < key[u'highMid']:
  260. max_highMid = key[u'highMid']
  261. if min_lowMid > key[u'lowMid']:
  262. min_lowMid = key[u'lowMid']
  263. #===============================
  264. if key[u'openMid'] >= key[u'closeMid']:
  265. high_body = key[u'openMid']
  266. low_body = key[u'closeMid']
  267. else:
  268. high_body = key[u'closeMid']
  269. low_body = key[u'openMid']
  270. #=================================
  271. if max_body < high_body:
  272. max_body = high_body
  273. if min_body > low_body:
  274. min_body = low_body
  275. volatil_candle = (max_highMid - min_lowMid) * 10000
  276. volatil_body = (max_body - min_body) * 10000
  277. if 'JPY' in instrument:
  278. volatil_body = float(volatil_body) / 100
  279. volatil_candle = float(volatil_candle) / 100
  280. hightoday = round(float(max_body + ((max_highMid - max_body)) / 2), 5)
  281. lowtoday = round(float(min_body - ((min_body - min_lowMid)) / 2), 5)
  282. todayvolatil = round(float((volatil_body + volatil_candle)) / 2, 1)
  283. return hightoday, lowtoday, todayvolatil
  284. except Exception as e:
  285. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  286.  
  287. def get_history_instrument(account_id, instrument, count):
  288. try:
  289. time.sleep(1)
  290. params = urllib.urlencode({})
  291. conn = httplib.HTTPSConnection(url)
  292. conn.request("GET", "/v1/accounts/" + account_id + "/transactions?instrument=" + instrument + '&count=' + str(count), params, headers)
  293. response = conn.getresponse()
  294. resptext = response.read()
  295. return resptext
  296. except Exception as e:
  297. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  298.  
  299. def get_history(account_id, count):
  300. try:
  301. time.sleep(1)
  302. params = urllib.urlencode({})
  303. conn = httplib.HTTPSConnection(url)
  304. conn.request("GET", "/v1/accounts/" + account_id + "/transactions?count=" + str(count), params, headers)
  305. response = conn.getresponse()
  306. resptext = response.read()
  307. return resptext
  308. except Exception as e:
  309. print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)

Решение задачи: «API функции для OANDA»

textual
Листинг программы
  1. def make_order(account_id, instrument, units, side,  exp, price, takeprofit, stoploss, trailingstop, upperbound, lowerbound):
  2.     try:
  3.         time.sleep(1)
  4.         #now = datetime.now()
  5.         now = datetime.utcnow()
  6.         expire = now + timedelta(hours=exp)
  7.         expire = expire.isoformat('T') + "Z"
  8.         params = urllib.urlencode({"instrument": instrument,
  9.                                    "units": units,
  10.                                    "side": side,
  11.                                    "type": "marketIfTouched",
  12.                                    "expiry": expire,
  13.                                    "price": price,
  14.                                    "takeProfit": takeprofit,
  15.                                    "stopLoss": stoploss,
  16.                                    "trailingStop": trailingstop,
  17.                                    "upperBound": upperbound,
  18.                                    "lowerBound": lowerbound})
  19.         conn = httplib.HTTPSConnection(url)
  20.         conn.request("POST", "/v1/accounts/" + account_id + "/orders", params, headers)
  21.         response = conn.getresponse()
  22.         resptext = response.read()
  23.         return resptext
  24.     except Exception as e:
  25.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  26.  
  27.  
  28. def make_limit_order(account_id, instrument, units, side,  exp, price, takeprofit, stoploss, trailingstop):
  29.     try:
  30.         time.sleep(1)
  31.         #now = datetime.now()
  32.         now = datetime.utcnow()
  33.         expire = now + timedelta(days=exp)
  34.         expire = expire.isoformat('T') + "Z"
  35.         params = urllib.urlencode({"instrument": instrument,
  36.                                    "units": units,
  37.                                    "side": side,
  38.                                    "type": "limit",
  39.                                    "expiry": expire,
  40.                                    "price": price,
  41.                                    "takeProfit": takeprofit,
  42.                                    "stopLoss": stoploss,
  43.                                    "trailingStop": trailingstop})
  44.         conn = httplib.HTTPSConnection(url)
  45.         conn.request("POST", "/v1/accounts/" + account_id + "/orders", params, headers)
  46.         response = conn.getresponse()
  47.         resptext = response.read()
  48.         return resptext
  49.     except Exception as e:
  50.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  51.  
  52.  
  53. def del_orders(account_id, id):
  54.     try:
  55.         time.sleep(0.5)
  56.         params = urllib.urlencode({'accountId': account_id})
  57.         conn = httplib.HTTPSConnection(url)
  58.         conn.request("DELETE", "/v1/accounts/" + account_id + "/orders/" + str(id), params, headers)
  59.         response = conn.getresponse()
  60.         resptext = response.read()
  61.         if response.status == 403:
  62.             print str(id) + ' not closed'
  63.         elif response.status == 200:
  64.             print str(id) + ' closed'
  65.         return response.status
  66.     except Exception as e:
  67.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  68.  
  69.  
  70. def del_trades(account_id, id):
  71.     try:
  72.         time.sleep(0.5)
  73.         params = urllib.urlencode({'accountId': account_id})
  74.         conn = httplib.HTTPSConnection(url)
  75.         conn.request("DELETE", "/v1/accounts/" + account_id + "/trades/" + str(id), params, headers)
  76.         response = conn.getresponse()
  77.         resptext = response.read()
  78.         if response.status == 403:
  79.             print str(id) + ' not closed'
  80.         elif response.status == 200:
  81.             print str(id) + ' closed'
  82.         return response.status
  83.     except Exception as e:
  84.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  85.  
  86.  
  87. def close_all_orders(account_id):
  88.     try:
  89.         time.sleep(1)
  90.         for p in range(1):
  91.             data = get_orders(account_id)
  92.             data = json.loads(data)
  93.             time.sleep(1)
  94.             if 'orders' in data.keys():
  95.                 if data['orders']:
  96.                     print 'Close all orders for account N ' + str(account_id)
  97.                     for key in data['orders']:
  98.                         # print key[u'instrument']
  99.                         order_id = key['id']
  100.                         stat = del_orders(account_id, order_id)
  101.     except Exception as e:
  102.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  103.  
  104.  
  105. def close_all_trades(account_id):
  106.     try:
  107.         time.sleep(1)
  108.         for p in range(1):
  109.             data = get_trades(account_id)
  110.             data = json.loads(data)
  111.             time.sleep(1)
  112.             if 'trades' in data.keys():
  113.                 if data['trades']:
  114.                     print 'Close all trades for account N ' + str(account_id) + ' trying ' + str(p + 1)
  115.                     for key in data['trades']:
  116.                         order_id = key['id']
  117.                         stat = del_trades(account_id, order_id)
  118.     except Exception as e:
  119.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  120.  
  121.  
  122. def get_orders(account_id):
  123.     try:
  124.         time.sleep(1)
  125.         params = urllib.urlencode({'accountId': account_id})
  126.         conn = httplib.HTTPSConnection(url)
  127.         conn.request("GET", "/v1/accounts/" + account_id + "/orders", params, headers)
  128.         response = conn.getresponse()
  129.         resptext = response.read()
  130.         return resptext
  131.     except Exception as e:
  132.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  133.  
  134.  
  135. def get_orders_instrument(account_id, instrument, count):  # count максимальное количество, ордеров дефаулт 50
  136.     try:
  137.         time.sleep(1)
  138.         params = urllib.urlencode({'accountId': account_id})
  139.         conn = httplib.HTTPSConnection(url)
  140.         # GET "https://api-fxtrade.oanda.com/v1/accounts/12345/orders?instrument=EUR_USD&count=2"
  141.         conn.request("GET", "/v1/accounts/" + account_id + "/orders?instrument=" +
  142.                      instrument + '&count=' + str(count), params, headers)
  143.         response = conn.getresponse()
  144.         resptext = response.read()
  145.         return resptext
  146.     except Exception as e:
  147.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  148.  
  149.  
  150. def get_trades(account_id):
  151.     try:
  152.         time.sleep(1)
  153.         params = urllib.urlencode({'accountId': account_id})
  154.         conn = httplib.HTTPSConnection(url)
  155.         conn.request("GET", "/v1/accounts/" + account_id + "/trades", params, headers)
  156.         response = conn.getresponse()
  157.         resptext = response.read()
  158.         return resptext
  159.     except Exception as e:
  160.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  161.  
  162.  
  163. def get_trades_instrument(account_id, instrument):
  164.     try:
  165.         time.sleep(1)
  166.         params = urllib.urlencode({'accountId': account_id})
  167.         conn = httplib.HTTPSConnection(url)
  168.         conn.request("GET", "/v1/accounts/" + account_id + "/trades?instrument=" + instrument, params, headers)
  169.         response = conn.getresponse()
  170.         resptext = response.read()
  171.         return resptext
  172.     except Exception as e:
  173.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  174.  
  175.  
  176. def rename_file(newnamefile):
  177.     try:
  178.         dir = os.getcwd()  # Текущий каталог
  179.         files = os.listdir(dir)  # Список файлов в текущем каталоге
  180.         filterfiles = filter(lambda x: x.startswith('balans'), files)  # Фильтруем список по началу файла
  181.         if not filterfiles:
  182.             my_file = open('balans', 'w')
  183.             namefile = my_file.name
  184.             my_file.close()
  185.             os.rename(namefile, newnamefile)
  186.         else:
  187.             namefile = filterfiles[0]
  188.             os.rename(namefile, newnamefile)
  189.     except IOError:
  190.         print 'file busy'
  191.  
  192.  
  193. def get_balans(account_id):  # запрос баланса по счету
  194.     try:
  195.         time.sleep(1)
  196.         params = urllib.urlencode({'accountId': account_id})
  197.         conn = httplib.HTTPSConnection(url)
  198.         conn.request("GET", "/v1/accounts/" + account_id, params, headers)
  199.         response = conn.getresponse()
  200.         resptext = response.read()
  201.         if response.status == 200:
  202.             data = json.loads(resptext)
  203.             sredstva = float("%.2f" % data['balance']) + float("%.2f" % data['unrealizedPl'])
  204.             marginused = float("%.2f" % data['marginUsed'])
  205.             marginavail = float("%.2f" % data['marginAvail'])
  206.             currency = data['accountCurrency']
  207.             return sredstva, marginused, marginavail, currency
  208.     except Exception as e:
  209.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)
  210.  
  211.  
  212. def get_spred(instrument, period):
  213.     # 3600  - 1 hour
  214.     # 43200 - 12 hour
  215.     # 86400 - 1 day
  216.     try:
  217.         time.sleep(1)
  218.         params = urllib.urlencode({})
  219.         conn = httplib.HTTPSConnection(url)
  220.         conn.request("GET", "/labs/v1/spreads?instrument=" + instrument + "&period=" + period, params,
  221.                      headers)  # (таблица периодов на сайте Oanda Forex Labs)
  222.         response = conn.getresponse()
  223.         resptext = response.read()
  224.         # print resptext
  225.         if response.status == 200:
  226.             spred = 0
  227.             data = json.loads(resptext)
  228.             sumspred = 0
  229.             nspred = 0
  230.             max_spred = 0  # максимальный
  231.             min_spred = 999999  # минимальный
  232.             avg_spred = 999999  # минимальный
  233.  
  234.             for key in data[u'max']:
  235.                 if max_spred < round(key[1], 2):
  236.                     max_spred = round(key[1], 2)
  237.             for key in data[u'min']:
  238.                 if min_spred > round(key[1], 2):
  239.                     min_spred = round(key[1], 2)
  240.             for key in data[u'avg']:
  241.                 if avg_spred > round(key[1], 2):
  242.                     avg_spred = round(key[1], 2)
  243.             # print instrument, max_spred, min_spred, avg_spred
  244.             return max_spred, min_spred, avg_spred
  245.         else:
  246.             return 0
  247.     except Exception as e:
  248.         print sys._getframe().f_code.co_name + " @ Caught exception when connecting to stream\n" + str(e)

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

12   голосов , оценка 4.5 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы