The article “Stock Market Data: Obtaining Data, Visualization & Analysis in Python” first appeared on QuantInsti blog.
Are you looking to get stock market data and analyse the historical data in Python? You have come to right place.
After reading this, you will be able to:
- Get historical data for stocks
- Plot the stock market data and analyse the performance
- Get the fundamental, futures and options data
Yahoo Finance
One of the first sources from which you can get historical daily price-volume stock market data is Yahoo finance. You can usepandas_datareader
oryfinance
module to get the data and then can download or store in a csv file by using pandas.to_csv method.
If yfinance is not installed on your computer, then run the below line of code from your Jupyter Notebook to install yfinance.
!pip install yfinance
install yfinance.pyhosted with ❤ byGitHub
# Import yfinance packageimport yfinance as yf# Set the start and end datestart_date = '1990-01-01'end_date = '2021-07-12'# Set the tickerticker = 'AMZN'# Get the datadata = yf.download(ticker, start_date, end_date)# Print 5 rowsdata.tail()
amazon_data.pyhosted with ❤ byGitHub
To visualize the adjusted close price data, you can use the matplotlib library and plot method as shown below.
# Import matplotlib for plottingimport matplotlib.pyplot as plt%matplotlib inline# Plot adjusted close price datadata['Adj Close'].plot()plt.show()
plot_amazn_data.pyhosted with ❤ byGitHub
Data Source: Yahoo Finance
Let us improve the plot by resizing, giving appropriate labels and adding grid lines for better readability.
# Plot the adjusted close pricedata['Adj Close'].plot(figsize=(10, 7))# Define the label for the title of the figureplt.title("Adjusted Close Price of %s" % ticker, fontsize=16)# Define the labels for x-axis and y-axisplt.ylabel('Price', fontsize=14)plt.xlabel('Year', fontsize=14)# Plot the grid linesplt.grid(which="major", color='k', linestyle='-.', linewidth=0.5)# Show the plotplt.show()
plot_amzn_data_with_grids.pyhosted with ❤ byGitHub
Data Source: Yahoo Finance
Advantages
- Adjusted close price stock market data is available
- Most recentstock market datais available
- Doesn't require API key to fetch the stock market data
How to get Stock Market Data for different geographies?
To get stock market data for different geographies, search the ticker symbol on Yahoo finance and use that as the ticker.
Get stock market data for multiple tickers
To get the stock market data of multiple stock tickers, you can create a list of tickers and call theyfinance download methodfor each stock ticker.
For simplicity, I have created a dataframedata
to store the adjusted close price of the stocks.
# Import packagesimport yfinance as yfimport pandas as pd# Set the start and end datestart_date = '1990-01-01'end_date = '2021-07-12'# Define the ticker listtickers_list = ['AAPL', 'IBM', 'MSFT', 'WMT']# Create placeholder for datadata = pd.DataFrame(columns=tickers_list)# Fetch the datafor ticker in tickers_list: data[ticker] = yf.download(ticker, start_date, end_date)['Adj Close'] # Print first 5 rows of the datadata.head()
multiple_tickers_data.pyhosted with ❤ byGitHub
# Plot all the close pricesdata.plot(figsize=(10, 7))# Show the legendplt.legend()# Define the label for the title of the figureplt.title("Adjusted Close Price", fontsize=16)# Define the labels for x-axis and y-axisplt.ylabel('Price', fontsize=14)plt.xlabel('Year', fontsize=14)# Plot the grid linesplt.grid(which="major", color='k', linestyle='-.', linewidth=0.5)plt.show()
plot_multiple_tickers_data.pyhosted with ❤ byGitHub
Data Source: Yahoo Finance
Visit QuantInsti blog to learn how to retrieve data for S&P 500 stock tickers.
Join The Conversation
If you have a general question, it may already be covered in our FAQs. If you have an account-specific question or concern, please reach out to Client Services.
6 thoughts on “Stock Market Data: Obtaining Data, Visualization & Analysis in Python”
Great post! I really appreciate these step-by-step tutorials. Thank you!
Reply
Nothing makes us happier than satisfied customers.
Reply
appreciated
Reply
We hope you continue to enjoy IBKR Quant!
Reply
How can I get Analyst buy/hold/sell recommendations
Reply
Hello, we appreciate your question.
To see analyst recommendations in Fundamentals Explorer:
Select the company you are interested in and open the Fundamentals Explorer.
Go to the Analyst Rating tab.
The analyst recommendations will be displayed with the number of buy/hold/sell ratings.
Please view this FAQ for instructions to access Fundamental Explorer in TWS. https://www.ibkr.com/faq?id=89975331We hope this helps!
Reply
Leave a Reply
Disclosure: Interactive Brokers
Information posted on IBKR Campus that is provided by third-parties does NOT constitute a recommendation that you should contract for the services of that third party. Third-party participants who contribute to IBKR Campus are independent of Interactive Brokers and Interactive Brokers does not make any representations or warranties concerning the services offered, their past or future performance, or the accuracy of the information provided by the third party. Past performance is no guarantee of future results.
This material is from QuantInsti and is being posted with its permission. The views expressed in this material are solely those of the author and/or QuantInsti and Interactive Brokers is not endorsing or recommending any investment or trading discussed in the material. This material is not and should not be construed as an offer to buy or sell any security. It should not be construed as research or investment advice or a recommendation to buy, sell or hold any security or commodity. This material does not and is not intended to take into account the particular financial conditions, investment objectives or requirements of individual customers. Before acting on this material, you should consider whether it is suitable for your particular circ*mstances and, as necessary, seek professional advice.