stock-analysis
stock-analysis copied to clipboard
Simple to use interfaces for basic technical analysis of stocks.
Stock Analysis
Package for making elements of technical analysis of a stock easier. This package is meant to be a starting point for you to develop your own. As such, all the instructions for installing/setup will be assuming you will continue to develop on your end.
Setup
# should install requirements.txt packages
$ pip3 install -e stock-analysis # path to top level where setup.py is
# if not, install them explicitly
$ pip3 install -r requirements.txt
Usage
This section will show some of the functionality of each class; however, it is by no means exhaustive.
Getting data
from stock_analysis import StockReader
reader = StockReader('2017-01-01', '2018-12-31')
# get bitcoin data in USD
bitcoin = reader.get_bitcoin_data('USD')
# get faang data
fb, aapl, amzn, nflx, goog = (
reader.get_ticker_data(ticker)
for ticker in ['META', 'AAPL', 'AMZN', 'NFLX', 'GOOG']
)
# get S&P 500 data
sp = reader.get_index_data('S&P 500')
Grouping data
from stock_analysis.utils import group_stocks, describe_group
faang = group_stocks(
{
'Facebook': fb,
'Apple': aapl,
'Amazon': amzn,
'Netflix': nflx,
'Google': goog
}
)
# describe the group
describe_group(faang)
Building a portfolio
Groups assets by date and sums columns to build a portfolio.
from stock_analysis.utils import make_portfolio
faang_portfolio = make_portfolio(faang)
Visualizing data
Be sure to check out the other methods here for different plot types, reference lines, shaded regions, and more!
Single asset
Evolution over time:
import matplotlib.pyplot as plt
from stock_analysis import StockVisualizer
netflix_viz = StockVisualizer(nflx)
ax = netflix_viz.evolution_over_time(
'close',
figsize=(10, 4),
legend=False,
title='Netflix closing price over time'
)
netflix_viz.add_reference_line(
ax,
x=nflx.high.idxmax(),
color='k',
linestyle=':',
label=f'highest value ({nflx.high.idxmax():%b %d})',
alpha=0.5
)
ax.set_ylabel('price ($)')
plt.show()
data:image/s3,"s3://crabby-images/51215/512158500842196d1757c217452fe329d833ecdc" alt="line plot with reference line"
After hours trades:
netflix_viz.after_hours_trades()
plt.show()
data:image/s3,"s3://crabby-images/95679/95679db577e4c3dc95d1e5ec2944c2bdeb291ac2" alt="after hours trades plot"
Differential in closing price versus another asset:
netflix_viz.fill_between_other(fb)
plt.show()
data:image/s3,"s3://crabby-images/81ba3/81ba370e9f75a5a0ee8e85e4cc42a6b90eb081b2" alt="differential between NFLX and FB"
Candlestick plots with resampling (uses mplfinance
):
netflix_viz.candlestick(resample='2W', volume=True, xrotation=90, datetime_format='%Y-%b -')
data:image/s3,"s3://crabby-images/e685c/e685c965b7a784d69ca186f2ce0224222dd3fd30" alt="resampled candlestick plot"
Note: run help()
on StockVisualizer
for more visualizations
Asset groups
Correlation heatmap:
from stock_analysis import AssetGroupVisualizer
faang_viz = AssetGroupVisualizer(faang)
faang_viz.heatmap(True)
data:image/s3,"s3://crabby-images/cfa26/cfa260b98d8bc24168e95072fde6ee71e6655240" alt="correlation heatmap"
Note: run help()
on AssetGroupVisualizer
for more visualizations. This object has many of the visualizations of the StockVisualizer
class.
Analyzing data
Below are a few of the metrics you can calculate.
Single asset
from stock_analysis import StockAnalyzer
nflx_analyzer = StockAnalyzer(nflx)
nflx_analyzer.annualized_volatility()
Asset group
Methods of the StockAnalyzer
class can be accessed by name with the AssetGroupAnalyzer
class's analyze()
method.
from stock_analysis import AssetGroupAnalyzer
faang_analyzer = AssetGroupAnalyzer(faang)
faang_analyzer.analyze('annualized_volatility')
faang_analyzer.analyze('beta', index=sp)
Modeling
from stock_analysis import StockModeler
Time series decomposition
decomposition = StockModeler.decompose(nflx, 20)
fig = decomposition.plot()
plt.show()
data:image/s3,"s3://crabby-images/50bf1/50bf17776ea66eec051d2917810306de15ed4dca" alt="time series decomposition"
ARIMA
Build the model:
arima_model = StockModeler.arima(nflx, ar=10, i=1, ma=5)
Check the residuals:
StockModeler.plot_residuals(arima_model)
plt.show()
data:image/s3,"s3://crabby-images/bebe2/bebe2e28245c529741aee59cee597bb1d3d35d24" alt="ARIMA residuals"
Plot the predictions:
arima_ax = StockModeler.arima_predictions(
nflx, arima_model,
start='2019-01-01', end='2019-01-07',
title='ARIMA'
)
plt.show()
data:image/s3,"s3://crabby-images/d7934/d79347280e57f86a9fd54afe6e479f2b7eb04b43" alt="ARIMA predictions"
Linear regression
Build the model:
X, Y, lm = StockModeler.regression(nflx)
Check the residuals:
StockModeler.plot_residuals(lm)
plt.show()
data:image/s3,"s3://crabby-images/2ca49/2ca496a35caa17b16039db904d517a5aec4aac79" alt="linear regression residuals"
Plot the predictions:
linear_reg = StockModeler.regression_predictions(
nflx, lm,
start='2019-01-01', end='2019-01-07',
title='Linear Regression'
)
plt.show()
data:image/s3,"s3://crabby-images/168b3/168b317c1492ed5ff0fad12ec6cc25b67e28d738" alt="linear regression predictions"