Streaming Forex with Python SocketIO
This tutorial takes you through a Python SocketIO implementation. Understanding the difference between SocketIO and WebSocket is essential. However, that is not the scope of this article. To realize the reason behind the increasing popularity of SocketIO, I would like to request you work along with this tutorial.
We will use the client code and SocketIO server responding with TraderMade’s forex data. I am clarifying these aspects in the beginning as it is easy to work on one side of the example before diving deeper into the topic. At the same time, you will experience a practically used, real-life example.
On this note, let’s start.
Acquire Your SocketIO Key
It is essential to obtain your API key to retrieve live forex data from the SocketIO server. Please sign up for free by visiting https://tradermade.com/signup. Then, select SocketIO trial. You will get an API key. It is advisable to note this key securely for future reference.
Code Setup
We will begin the process by installing the required libraries. It is important to note that TraderMade’s SocketIO is compatible with Version 2X only.
python-engineio==3.14.2
python-socketio==4.3.1
We may need other dependencies, yet these two should be the same to work with this example.
A brief on the method to retrieve live forex data
Let’s understand how real-time forex data is obtained through SocketIO using Python:
The data transfer between client and server occurs as events in SocketIO.
The events establish communication between the client and server.
Read this tutorial further to know more about how events help execute communication between client and server.
Client-side Code
We will go step by step. To start with, we will import SocketIO. Then create an object - “Sio,” to create a client. We will use this to connect to the URL.
import socketio
# standard Python
sio = socketio.Client()
Firstly, we will obtain an object and then set up an event to initiate a connection with TraderMade’s SocketIO server. We will place an event with def connect (). When we connect with the server, this function will be called on.
@sio.event
def connect():
print("I'm connected!")
sio.emit('login', {'userKey': 'Your Streaming API Key'})
After getting connected, we will release an event to the server - “login.” After signing up initially, we received an API key. We will send that API key in JSON format to the server to set our identity. You might have realised that some events listen to specific information. We will keep perceiving the next steps.
@sio.even
def connect_error():
print("The connection failed!")
@sio.on('handshake')
def on_message(data):
print('HandShake', data)
sio.emit('symbolSub', {'symbol': 'EURUSD'})
We can easily make out what ‘Connect-error’ is. TraderMade’s server sends or emits an event - handshake. We need this event on the SocketIO client-side code. It is essential to maintain the communication chain and obtain data.
Thus, you can realize that some events send data. After receiving the ‘handshake’ event, we will print the data transmitted.
Received from Server
Welcome to the TMS Data Feed
It is possible to obtain forex data. However, the server should know that we need that. At this stage, we need to subscribe to a Symbol by discharging an event - “SymbolSub.” Along with that, we will send {‘symbol’: ‘EURUSD’} as the data from the client side.
@sio.on('price')
def on_message(data):
print('Price Data ', data)
sio.connect('
https://marketdata.tradermade.com
')
We can see how the above event pushes data. We require the URL at the end to set up the connection once we know the code. There it is! We can now obtain forex rates for EURUSD also with a timestamp.
Received from Server
Price Data EURUSD 1.20543 1.20543 1.20543 20210303–14:27:59.496
Please have a glance at the complete set of codes here:
import socketio
# standard Python
sio = socketio.Client()
@sio.event
def connect():
print("I'm connected!")
sio.emit('login', {'userKey': 'streaming_api_key'})
@sio.event
def connect_error():
print("The connection failed!")
@sio.event
def message(data):
print('I received a message!')
@sio.on('handshake')
def on_message(data):
print('HandShake', data)
sio.emit('symbolSub', {'symbol': 'USDJPY'})
sio.emit('symbolSub', {'symbol': 'GBPUSD'})
sio.emit('symbolSub', {'symbol': 'EURUSD'})
@sio.on('price')
def on_message(data):
print('Price Data ', data)
sio.connect('
https://marketdata.tradermade.com
')
I anticipate that the tutorial will help you. We will come back with more such tutorials.
Please take a glance at the originally published tutorial on the TraderMade website:
Subscribe to my newsletter
Read articles from Shridhar G V directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
Shridhar G V
Shridhar G V
I have been passionate about the latest technology used in the financial services landscape. I like to share articles and tutorials to help fellow developers.