fia (financial analyzer) package for Python.
Project description
FInancial Analyzer (fia)
Overview
fia (FInancial Analyzer) is a package that gets the historical market data from multiple resources such as TradingView, Alphavantage, etc.
The package collects the data from TradingView over WebSocket. In the future, other options and resources will be added.
Installation
The source code is hosted on GitHub.
Before the package installation, it is recommended to create a new virtual environment by conda, virtualenv, poetry, and so on.
The dependencies are listed in pyproject.toml in the dependencies section.
To install the package use the following commands in Terminal:
- For PyPI:
pip install fia
The simplest working example
from fia import Frame, set_logger, TvDataCollector
# Set the logger to see the INFO messages.
set_logger("INFO")
# Create an instance of the TvDataCollector class.
tvdc = TvDataCollector(username="Red69",
password="fhEnv@*re37",
exchange="NASDAQ",
ticker_sym="AAPL",
currency="USD",
frame=Frame.MIN15,
bars=50)
# Get the raw data including the historical market data.
raw_data = tvdc.get_data()
# Get the clean historical market data as DataFrame object.
df = tvdc.get_pandas_data(raw_data, tz="America/Chicago")
See the detailed explanation below in the Usage section.
Usage
There are two ways how the package can be used:
- Over command line interface.
- As an imported package in Python (recommended method).
The 1st method (command line interface):
The 1st method returns only a CSV file with the historical market data. This file can be used by a user in other software and apps to analyze the data. It is designed for people who are not going to use Python as the main tool and need only the file with the historical market data.
Method 1.1 (CLI + environment variables):
-
Go to the project directory and create setenv.sh
-
Add the following lines in the file:
export TV_USERNAME="USERNAME" export TV_PASSWORD="PASSWORD"
where:
- "USERNAME" is a TradingView username (not to be confused with email).
- "PASSWORD" is a TradingView password.
For example:
export TV_USERNAME="Red69" export TV_PASSWORD="fhEnv@*re37"
-
From Terminal export the environment variables:
. ./setenv.sh
-
Type the command in Terminal:
fia -e exchange -t ticker_sym -c currency -f frame -b bars
where:
- exchange is an exchange (NYSE, CME, etc.).
- ticker_sym is a ticker symbol (AAPL, BTC, etc.)
- currency is a currency (USD, EUR, etc.).
- frame is a bar timeframe. Use one of the following options:
- MIN1 - 1 min,
- MIN5 - 5 min,
- MIN15 - 15 min,
- MIN30 - 30 min,
- MIN45 - 45 min,
- HOUR1 - 1 hr,
- HOUR2 - 2 hr,
- HOUR3 - 3 hr,
- HOUR4 - 4 hr,
- DAY - day,
- WEEK - week,
- MONTH - month.
- bars is a number of bars (the limit depends on the Tradingview plan and the ticker symbol).
- user_agent is a user agent (optional), use the -a flag if you would like to change the default value.
- remember is a status (optional), "on" - remember the user, use the -r flag if you would like to change the default value.
For example:
fia -e NASDAQ -t AAPL -c USD -f DAY -b 50
-
It creates a CSV file that has the file name is similar to "TICKER_SYM_FRAME_DATE_TIME" (for example, AAPL_NASDAQ_DAY_20221123_10_21_49) and saves it in the fia_output folder. The fia_output folder is created in your home (~, $HOME, etc.) folder.
An example of output CSV file:
DateTime,Open,High,Low,Close,Volume 2022-09-15 08:30:00-05:00,154.65,155.24,151.38,152.37,90481110.0 2022-09-16 08:30:00-05:00,151.21,151.35,148.37,150.7,162278841.0 ................................................................. 2022-11-22 08:30:00-06:00,148.13,150.42,146.925,150.18,51804132.0 2022-11-23 08:30:00-06:00,149.45,151.83,149.34,151.07,58301395.0
There are 6 values in every row separated by comma:
- DateTime: date and time. The UTC timezone is used.
- Open: the opening price of the chosen timeframe.
- High: the highest price of the chosen timeframe.
- Low: the lowest price of the chosen timeframe.
- Close: the closing price of the chosen timeframe.
- Volume: the market volume.
The values usually are in USD but check the currency and the unit of measure on the exchange.
-
Add setenv.sh in the .gitignore file for security reasons if you are going to create a repository on a platform is similar to GitHub.
Method 1.2 (CLI + explicit username and password):
This method is not recommended because it is not secure. It is better to use the environment variables to keep your username and password as it was described above in Method 1.1.
Type the command in Terminal:
fia -u username -p password -e exchange -t ticker_sym -c currency -f frame -b bars
where:
- username is a TradingView username (not to be confused with email).
- password is a TradingView password.
- exchange is an exchange (NYSE, CME, etc.).
- ticker_sym is a ticker symbol (AAPL, BTC, etc.)
- currency is a currency (USD, EUR, etc.).
- frame is a bar timeframe. Use one of the following options:
- MIN1 - 1 min,
- MIN5 - 5 min,
- MIN15 - 15 min,
- MIN30 - 30 min,
- MIN45 - 45 min,
- HOUR1 - 1 hr,
- HOUR2 - 2 hr,
- HOUR3 - 3 hr,
- HOUR4 - 4 hr,
- DAY - day,
- WEEK - week,
- MONTH - month.
- bars is a number of bars (the limit depends on the Tradingview plan and the ticker symbol).
- user_agent is a user agent (optional), use the -a flag if you would like to change the default value.
- remember is a status (optional), "on" - remember the user, use the -r flag if you would like to change the default value.
For example:
fia -u Red69 -p fhEnv@*re37 -e NASDAQ -t AAPL -c USD -f DAY -b 50
The 2nd method (import as a Python package):
The 2nd method is a recommended usage because it is more flexible and can work with other Python libraries.
It can return:
- the raw market data received over WebSocket,
- the market data in JSON format,
- the market data as a Pandas DataFrame object.
It is designed for people who would like to use the package with Pandas, Matplotlib, JupyterLab, etc.
Method 2.1 (import + environment variables):
-
Go to the project directory and create setenv.sh
-
Add the following lines in the file:
export TV_USERNAME="USERNAME" export TV_PASSWORD="PASSWORD"
where:
- "USERNAME" is a TradingView username (not to be confused with email).
- "PASSWORD" is a TradingView password.
For example:
export TV_USERNAME="Red69" export TV_PASSWORD="fhEnv@*re37"
-
From Terminal export the environment variables:
. ./setenv.sh
-
Create a python file and get the historical market data:
import os # Import the fia package the TvDataCollector class and the Frame enum. from fia import Frame, TvDataCollector # Create an instance of the TvDataCollector class. tvdc = TvDataCollector(username=os.environ.get("TV_USERNAME"), password=os.environ.get("TV_PASSWORD"), exchange="NASDAQ", ticker_sym="AAPL", currency="USD", frame=Frame.MIN15, bars=50) # Get the raw data including the historical market data. raw_data = tvdc.get_data() # Get the clean historical market data as DataFrame object. df = tvdc.get_pandas_data(raw_data)
The TvDataCollector class gets the historical market data from TradingView and has the following attributes:
- username is a TradingView username (not to be confused with email).
- password is a TradingView password.
- exchange is an exchange (NYSE, CME, etc.).
- ticker_sym is a ticker symbol (AAPL, BTC, etc.)
- currency is a currency (USD, EUR, etc.).
- frame is a bar timeframe as a member of enum Frame. Use one of the following
options:
- Frame.MIN1 - 1 min,
- Frame.MIN5 - 5 min,
- Frame.MIN15 - 15 min,
- Frame.MIN30 - 30 min,
- Frame.MIN45 - 45 min,
- Frame.HOUR1 - 1 hr,
- Frame.HOUR2 - 2 hr,
- Frame.HOUR3 - 3 hr,
- Frame.HOUR4 - 4 hr,
- Frame.DAY - day,
- Frame.WEEK - week,
- Frame.MONTH - month.
- bars is a number of bars (the limit depends on the Tradingview plan and the ticker symbol).
- user_agent is a user agent (optional), use the -a flag if you would like to change the default value.
- remember is a status (optional), "on" - remember the user, use the -r flag if you would like to change the default value.
The TvDataCollector has the following public methods:
-
get_auth_token(): Gets the authorization token. The following code
# tvdc is an instance of the TvDataCollector class. tvdc.get_auth_token()
returns the authorization token generated for your username on TradingView when you sign in.
-
get_data(): Gets the raw data over Websocket.
The following code# tvdc is an instance of the TvDataCollector class. tvdc.get_data()
returns the raw data including the historical market data.
It includes all sent and received messages over WebSocket. It can be useful if you would like to parse the raw data and use what you need for your goals.
-
get_pandas_data(raw_data, tz): Gets the market data as Pandas DataFrame from the raw data. The tz argument is optional. The UTC time is used by default. Any time zone from pytz.all_timezones (see the python library pytz) can be used. For example, "America/Chicago" is CME timezone.
The following code
# tvdc is an instance of the TvDataCollector class. # raw_data is received by using tvdc.get_data(). tvdc.get_pandas_data(raw_data)
returns the DataFrame object:
DateTime | Open | High | Low | Close | Volume |
---|---|---|---|---|---|
2022-09-14 13:30:00+00:00 | 154.785 | 157.1 | 153.6106 | 155.31 | 87965409.0 |
2022-09-15 13:30:00+00:00 | 154.65 | 155.24 | 151.38 | 152.37 | 90481110.0 |
… | … | … | … | … | … |
2022-11-21 14:30:00+00:00 | 150.16 | 150.37 | 147.715 | 148.01 | 58724070.0 |
2022-11-22 14:30:00+00:00 | 148.13 | 150.42 | 146.925 | 150.18 | 51804132.0 |
There are 6 columns:
-
DateTime: date and time. It depends on the tz argument value in get_pandas_data(). The UTC time is used by default.
-
Open: the opening price of the chosen timeframe.
-
High: the highest price of the chosen timeframe.
-
Low: the lowest price of the chosen timeframe.
-
Close: the closing price of the chosen timeframe.
-
Volume: the market volume.
The price values usually are in USD but check the currency and the unit of measure on the exchange. If you would like to change the timezone see the following example:# tvdc is an instance of the TvDataCollector class. # raw_data is received by using tvdc.get_data(). # "America/Chicago" is a timezone. Any time zone from pytz.all_timezones # (see the python library pytz) can be used. tvdc.get_pandas_data(raw_data, "America/Chicago")
-
get_json_data(raw_data): Gets the market data in JSON format from the raw data. The following code
# tvdc is an instance of the TvDataCollector class. # raw_data is received by using tvdc.get_data(). tvdc.get_json_data(raw_data)
returns the data in JSON format.
- Add setenv.sh in the .gitignore file for security reasons if you are going to create a repository on a platform is similar to GitHub.
Method 2.2 (import + explicit username and password):
This method is not recommended because it is not secure. It is better to use the environment variables to keep your username and password as it was described above in Method 2.1.
Create a python file and get the historical market data:
# Import the fia package the TvDataCollector class and the Frame enum.
from fia import Frame, TvDataCollector
# Create an instance of the TvDataCollector class.
tvdc = TvDataCollector(username="Red69",
password="fhEnv@*re37",
exchange="NASDAQ",
ticker_sym="AAPL",
currency="USD",
frame=Frame.MIN15,
bars=50)
# Get the raw data including the historical market data.
raw_data = tvdc.get_data()
# Get the clean historical market data as DataFrame object.
df = tvdc.get_pandas_data(raw_data)
The attributes and methods are described in Method 2.1. The only difference is that we assign the explicit username and password rather than using os.environ.get() to get them from the environment variables.
Logging
-
When the package is used over command line interface the root logger is set by default and shows the info messages.
-
When the package is imported the root logger is not set. It prevents collisions with the logging system of the program where the package was imported.
There are several ways how to set the logger:
- Use the set_logger() function that sets the root logger and helps to choose
the level of log messages:
# import functions set_logger() from fia import set_logger # Set status: "INFO", "DEBUG", "WARNING", etc. set_logger("INFO")
- Set the root logger manually.
import logging import sys # Get the root logger. logger = logging.getLogger() # Set the level of messages for the logger. logger.setLevel(logging.DEBUG) # Set the log message style. formatter = logging.Formatter( "{asctime} | {name} | {levelname} | {message}", style="{" ) # Set and attach the handler. handler = logging.StreamHandler(sys.stdout) handler.setLevel(logging.DEBUG) handler.setFormatter(formatter) logger.addHandler(handler)
- Set the package logger manually.
import logging import sys # Get the logger. logger = logging.getLogger("fia") # Set the level of messages for the logger. logger.setLevel(logging.DEBUG) # Set the log message style. formatter = logging.Formatter( "{asctime} | {name} | {levelname} | {message}", style="{" ) # Set and attach the handler. handler = logging.StreamHandler(sys.stdout) handler.setLevel(logging.DEBUG) handler.setFormatter(formatter) logger.addHandler(handler)
Choose the most suitable method for your case.
- Use the set_logger() function that sets the root logger and helps to choose
the level of log messages:
Important notes
You should treat the historical data accurately especially the last bar.
For example, when you use the day timeframe, the last bar represents the actual prices and volume for the current day. If the market is active the prices and volume keep changing.
A similar situation occurs when you try to retrieve the data in the middle of the week, month, etc.
License
Disclaimer
The fia package and any results received by using the fia package are for informational and educational purposes only. You should not construe any such information or other material as legal, tax, investment, financial, or other advice. There are risks associated with investing in any securities and assets. Do your own research. Past performance is not a guarantee of future return or performance. You may gain or lose money.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file fia-0.2.0.tar.gz
.
File metadata
- Download URL: fia-0.2.0.tar.gz
- Upload date:
- Size: 30.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7382f5d0c8114b38ad0cc241d422506f76abb20fa5a12270e7cdc8b557899786 |
|
MD5 | 62e902c00ae383b87e4eaa844311ac09 |
|
BLAKE2b-256 | a9e9efac75d63f65000cb0436de7b9fcc9a61b441ed624f213211299ff842508 |