-
Notifications
You must be signed in to change notification settings - Fork 3
Getting Started
Create a simple python wrapper around alpha vantage api. Normalize responses so you have consistency across end points. Provide direct access to each end point so customers who already use the API can have the flexibility. Make it easy to debug, so users can track down issues quickly.
- You can find alpha vantage here: https://www.alphavantage.co/
- See the alpha vantage api documentation: https://www.alphavantage.co/documentation/
- Get your free api key here: https://www.alphavantage.co/support/#api-key
- How to Install
- How to Specify API Key
- Obtain Stock Price
- Obtain Accouting / Financial Statements
- Debugging / Logging
- Retry / Cache (optimize your free account!)
pip install alphavantage_api_client
There are a few ways you include your API Key:
from alphavantage_api_client import AlphavantageClient
client = AlphavantageClient()
event = {
"symbol": "ibm",
"interval": "5min",
"apikey" : "[your key here]"
}
global_quote = client.get_global_quote(event)
assert global_quote.success, "Success field is missing or False"
assert not global_quote.limit_reached, "Limit reached is true but not hitting API"
assert global_quote.symbol == event["symbol"], "Symbol from results don't match event"
assert "meta_data" not in global_quote, "Metadata should not be present since it's not in the api"
assert len(global_quote.data) > 0, "Data field is zero or not present"
print(f"Response data {global_quote.json()}")
from alphavantage_api_client import AlphavantageClient
client = AlphavantageClient().with_api_key("[your api key here]")
event = {
"symbol": "ibm",
"interval": "5min"
}
global_quote = client.get_global_quote(event)
assert global_quote.success, "Success field is missing or False"
assert not global_quote.limit_reached, "Limit reached is true but not hitting API"
assert global_quote.symbol == event["symbol"], "Symbol from results don't match event"
assert "meta_data" not in global_quote, "Metadata should not be present since it's not in the api"
assert len(global_quote.data) > 0, "Data field is zero or not present"
print(f"Response data {global_quote.json()}")
export ALPHAVANTAGE_API_KEY=[your key here]
from alphavantage_api_client import AlphavantageClient
client = AlphavantageClient()
event = {
"symbol": "ibm",
"interval": "5min"
}
global_quote = client.get_global_quote(event)
assert global_quote.success, "Success field is missing or False"
assert not global_quote.limit_reached, "Limit reached is true but not hitting API"
assert global_quote.symbol == event["symbol"], "Symbol from results don't match event"
assert "meta_data" not in global_quote, "Metadata should not be present since it's not in the api"
assert len(global_quote.data) > 0, "Data field is zero or not present"
print(f"Response data {global_quote.json()}")
echo -e "[access]\napi_key=[your key here]" > ~/.alphavantage
from alphavantage_api_client import AlphavantageClient
client = AlphavantageClient()
event = {
"symbol": "ibm",
"interval": "5min"
}
global_quote = client.get_global_quote(event)
assert global_quote.success, "Success field is missing or False"
assert not global_quote.limit_reached, "Limit reached is true but not hitting API"
assert global_quote.symbol == event["symbol"], "Symbol from results don't match event"
assert "meta_data" not in global_quote, "Metadata should not be present since it's not in the api"
assert len(global_quote.data) > 0, "Data field is zero or not present"
print(f"Response data {global_quote.json()}")
from alphavantage_api_client import AlphavantageClient, GlobalQuote
def sample_global_quote():
client = AlphavantageClient()
global_quote = client.get_global_quote("TSLA")
if not global_quote.success:
raise ValueError(f"{global_quote.error_message}")
print(global_quote.json()) # convenience method that will convert to json
print(f"stock price: ${global_quote.get_price()}") # convenience method to get stock price
print(f"trade volume: {global_quote.get_volume()}") # convenience method to get volume
print(f"low price: ${global_quote.get_low_price()}") # convenience method to get low price for the day
# and more!
if __name__ == "__main__":
sample_global_quote()
returns the following output
{"success": true, "limit_reached": false, "status_code": 200, "error_message": null, "csv": null, "symbol": "TSLA", "data": {"01. symbol": "TSLA", "02. open": "259.2900", "03. high": "262.4500", "04. low": "252.8000", "05. price": "256.6000", "06. volume": "177460803", "07. latest trading day": "2023-06-23", "08. previous close": "264.6100", "09. change": "-8.0100", "10. change percent": "-3.0271%"}}
stock price: $256.6000
trade volume: 177460803
low price: $252.8000
There are 4 different accounting reports:
- Cash Flow - A cash flow statement is a financial statement that provides information about the cash inflows and outflows of a company during a specific period of time. It helps investors understand how a company generates and uses cash.
- Balance Sheet - a financial statement that provides a snapshot of a company's financial position at a specific point in time. It shows the company's assets, liabilities, and shareholders' equity.
- Income Statement - also known as a profit and loss statement or P&L statement, is a financial statement that provides an overview of a company's revenues, expenses, and net income or loss over a specific period of time. It is one of the key financial statements used by investors to assess a company's profitability and financial performance.
- Earnings Statements - An earnings statement, also known as an earnings report or earnings statement, is a financial statement that provides an overview of a company's revenue, expenses, and profit or loss for a specific period of time. It is commonly used by investors to evaluate a company's financial performance.
from alphavantage_api_client import AlphavantageClient, GlobalQuote, AccountingReport
def sample_accounting_reports():
client = AlphavantageClient()
earnings = client.get_earnings("TSLA")
cash_flow = client.get_cash_flow("TSLA")
balance_sheet = client.get_balance_sheet("TSLA")
income_statement = client.get_income_statement("TSLA")
reports = [earnings,cash_flow, balance_sheet, income_statement]
# show that each report is in the same type and how to access the annual and quarterly reports
for accounting_report in reports:
if not accounting_report.success:
raise ValueError(f"{accounting_report.error_message}")
print(accounting_report.json())
print(accounting_report.quarterlyReports) # array of all quarterly report
print(accounting_report.annualReports) # array of all annual reports
print(accounting_report.get_most_recent_annual_report()) # get the most recent annual report
print(accounting_report.get_most_recent_quarterly_report()) # get the most recent quarterly report;
if __name__ == "__main__":
sample_accounting_reports()
We use the built in import logging
library in python. Obtaining more information from the client behavior
is as simple as adjusting your log levels.
-
logging.INFO
- This will get you json log statements (in case you put these into splunk or cloudwatch) that show which method is doing the work, the action, and the value or data is produced (where applicable).{ "method": "__init__", "action": "/home/[your user name]/.alphavantage config file found" }
Example log during client.global_quote(...) call. The data property is the raw response from alpha vantage api:
{ "method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"TSLA\",\n \"02. open\": \"712.4050\",\n \"03. high\": \"738.2000\",\n \"04. low\": \"708.2600\",\n \"05. price\": \"737.1200\",\n \"06. volume\": \"31923565\",\n \"07. latest trading day\": \"2022-06-24\",\n \"08. previous close\": \"705.2100\",\n \"09. change\": \"31.9100\",\n \"10. change percent\": \"4.5249%\"\n }\n}" }
{ "method": "get_data_from_alpha_vantage", "action": "return_value", "data": { "success": true, "limit_reached": false, "status_code": 200, "Global Quote": { "01. symbol": "TSLA", "02. open": "712.4050", "03. high": "738.2000", "04. low": "708.2600", "05. price": "737.1200", "06. volume": "31923565", "07. latest trading day": "2022-06-24", "08. previous close": "705.2100", "09. change": "31.9100", "10. change percent": "4.5249%" }, "symbol": "tsla" } }
-
logging.DEBUG
- This will get you all of the log statements from #1 and from the dependant libraries.INFO:root:{"method": "__init__", "action": "/home/[your username]/.alphavantage config file found"} DEBUG:urllib3.connectionpool:Starting new HTTPS connection (1): www.alphavantage.co:443 DEBUG:urllib3.connectionpool:https://www.alphavantage.co:443 "GET /query?symbol=tsla&function=GLOBAL_QUOTE&apikey=YRV1XL63GDIFS42A HTTP/1.1" 200 None INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"TSLA\",\n \"02. open\": \"712.4050\",\n \"03. high\": \"738.2000\",\n \"04. low\": \"708.2600\",\n \"05. price\": \"737.1200\",\n \"06. volume\": \"31923565\",\n \"07. latest trading day\": \"2022-06-24\",\n \"08. previous close\": \"705.2100\",\n \"09. change\": \"31.9100\",\n \"10. change percent\": \"4.5249%\"\n }\n}"} INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "TSLA", "02. open": "712.4050", "03. high": "738.2000", "04. low": "708.2600", "05. price": "737.1200", "06. volume": "31923565", "07. latest trading day": "2022-06-24", "08. previous close": "705.2100", "09. change": "31.9100", "10. change percent": "4.5249%"}, "symbol": "tsla"}}
A free account only allows so many calls per min. You can configure the client to use a simple cache and retry if it detects your limit has been reached. This way you can get the most out of your free tier :-)
from alphavantage_api_client import AlphavantageClient, GlobalQuote
import logging
def sample_retry_when_limit_reached():
logging.basicConfig(level=logging.INFO)
client = AlphavantageClient().use_simple_cache().should_retry_once()
symbols = ["TSLA","F","C","WFC","ZIM","PXD","PXD","POOL","INTC","INTU"] # more than 5 calls so should fail
for symbol in symbols:
event = {
"symbol": symbol
}
global_quote = client.get_global_quote(event)
if not global_quote.success:
raise ValueError(f"{global_quote.error_message}")
if global_quote.limit_reached:
raise ValueError(f"{global_quote.error_message}")
print(f"symbol: {global_quote.symbol}, Price: {global_quote.get_price()}, success {global_quote.success}")
client.clear_cache() # when you are done making calls, clear cache
if __name__ == "__main__":
sample_retry_when_limit_reached()
Produces output (note: logging.INFO
has been turned on)
INFO:root:{"method": "__init__", "action": "/home/xrgarcia/.alphavantage config file found"}
INFO:root:Found item in cache: None
symbol: TSLA, Price: 241.0500, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"TSLA\",\n \"02. open\": \"250.0650\",\n \"03. high\": \"258.3700\",\n \"04. low\": \"240.7000\",\n \"05. price\": \"241.0500\",\n \"06. volume\": \"179990552\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"256.6000\",\n \"09. change\": \"-15.5500\",\n \"10. change percent\": \"-6.0600%\"\n }\n}", "event": {"symbol": "TSLA", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "TSLA", "02. open": "250.0650", "03. high": "258.3700", "04. low": "240.7000", "05. price": "241.0500", "06. volume": "179990552", "07. latest trading day": "2023-06-26", "08. previous close": "256.6000", "09. change": "-15.5500", "10. change percent": "-6.0600%"}, "symbol": "TSLA"}, "event": {"symbol": "TSLA", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"F\",\n \"02. open\": \"14.0100\",\n \"03. high\": \"14.2300\",\n \"04. low\": \"13.9900\",\n \"05. price\": \"14.1100\",\n \"06. volume\": \"44956274\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"14.0200\",\n \"09. change\": \"0.0900\",\n \"10. change percent\": \"0.6419%\"\n }\n}", "event": {"symbol": "F", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "F", "02. open": "14.0100", "03. high": "14.2300", "04. low": "13.9900", "05. price": "14.1100", "06. volume": "44956274", "07. latest trading day": "2023-06-26", "08. previous close": "14.0200", "09. change": "0.0900", "10. change percent": "0.6419%"}, "symbol": "F"}, "event": {"symbol": "F", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
symbol: F, Price: 14.1100, success True
symbol: C, Price: 46.2400, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"C\",\n \"02. open\": \"46.1200\",\n \"03. high\": \"46.6900\",\n \"04. low\": \"46.0100\",\n \"05. price\": \"46.2400\",\n \"06. volume\": \"13253938\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"46.0200\",\n \"09. change\": \"0.2200\",\n \"10. change percent\": \"0.4781%\"\n }\n}", "event": {"symbol": "C", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "C", "02. open": "46.1200", "03. high": "46.6900", "04. low": "46.0100", "05. price": "46.2400", "06. volume": "13253938", "07. latest trading day": "2023-06-26", "08. previous close": "46.0200", "09. change": "0.2200", "10. change percent": "0.4781%"}, "symbol": "C"}, "event": {"symbol": "C", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"WFC\",\n \"02. open\": \"40.7800\",\n \"03. high\": \"41.2200\",\n \"04. low\": \"40.4550\",\n \"05. price\": \"40.5900\",\n \"06. volume\": \"13618534\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"40.6100\",\n \"09. change\": \"-0.0200\",\n \"10. change percent\": \"-0.0492%\"\n }\n}", "event": {"symbol": "WFC", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "WFC", "02. open": "40.7800", "03. high": "41.2200", "04. low": "40.4550", "05. price": "40.5900", "06. volume": "13618534", "07. latest trading day": "2023-06-26", "08. previous close": "40.6100", "09. change": "-0.0200", "10. change percent": "-0.0492%"}, "symbol": "WFC"}, "event": {"symbol": "WFC", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
symbol: WFC, Price: 40.5900, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"ZIM\",\n \"02. open\": \"12.1000\",\n \"03. high\": \"12.2375\",\n \"04. low\": \"11.9450\",\n \"05. price\": \"12.0900\",\n \"06. volume\": \"2206381\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"12.1800\",\n \"09. change\": \"-0.0900\",\n \"10. change percent\": \"-0.7389%\"\n }\n}", "event": {"symbol": "ZIM", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "ZIM", "02. open": "12.1000", "03. high": "12.2375", "04. low": "11.9450", "05. price": "12.0900", "06. volume": "2206381", "07. latest trading day": "2023-06-26", "08. previous close": "12.1800", "09. change": "-0.0900", "10. change percent": "-0.7389%"}, "symbol": "ZIM"}, "event": {"symbol": "ZIM", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
symbol: ZIM, Price: 12.0900, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Note\": \"Thank you for using Alpha Vantage! Our standard API call frequency is 5 calls per minute and 500 calls per day. Please visit https://www.alphavantage.co/premium/ if you would like to target a higher API call frequency.\"\n}", "event": {"symbol": "PXD", "function": "GLOBAL_QUOTE"}}
INFO:root:sleeping for 59.31067372301186 seconds
INFO:root:Found item in cache: None
symbol: PXD, Price: 201.3800, success True
symbol: PXD, Price: 201.3800, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"PXD\",\n \"02. open\": \"199.3500\",\n \"03. high\": \"202.9600\",\n \"04. low\": \"199.0100\",\n \"05. price\": \"201.3800\",\n \"06. volume\": \"1331532\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"198.6600\",\n \"09. change\": \"2.7200\",\n \"10. change percent\": \"1.3692%\"\n }\n}", "event": {"symbol": "PXD", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "PXD", "02. open": "199.3500", "03. high": "202.9600", "04. low": "199.0100", "05. price": "201.3800", "06. volume": "1331532", "07. latest trading day": "2023-06-26", "08. previous close": "198.6600", "09. change": "2.7200", "10. change percent": "1.3692%"}, "symbol": "PXD"}, "event": {"symbol": "PXD", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: {'success': True, 'limit_reached': False, 'status_code': 200, 'Global Quote': {'01. symbol': 'PXD', '02. open': '199.3500', '03. high': '202.9600', '04. low': '199.0100', '05. price': '201.3800', '06. volume': '1331532', '07. latest trading day': '2023-06-26', '08. previous close': '198.6600', '09. change': '2.7200', '10. change percent': '1.3692%'}, 'symbol': 'PXD'}
INFO:root:Found item in cache: None
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"POOL\",\n \"02. open\": \"350.2500\",\n \"03. high\": \"356.7900\",\n \"04. low\": \"349.0100\",\n \"05. price\": \"354.1300\",\n \"06. volume\": \"292565\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"352.3400\",\n \"09. change\": \"1.7900\",\n \"10. change percent\": \"0.5080%\"\n }\n}", "event": {"symbol": "POOL", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "POOL", "02. open": "350.2500", "03. high": "356.7900", "04. low": "349.0100", "05. price": "354.1300", "06. volume": "292565", "07. latest trading day": "2023-06-26", "08. previous close": "352.3400", "09. change": "1.7900", "10. change percent": "0.5080%"}, "symbol": "POOL"}, "event": {"symbol": "POOL", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
symbol: POOL, Price: 354.1300, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"INTC\",\n \"02. open\": \"33.1900\",\n \"03. high\": \"33.9900\",\n \"04. low\": \"33.0950\",\n \"05. price\": \"33.3400\",\n \"06. volume\": \"38952369\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"33.0000\",\n \"09. change\": \"0.3400\",\n \"10. change percent\": \"1.0303%\"\n }\n}", "event": {"symbol": "INTC", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "INTC", "02. open": "33.1900", "03. high": "33.9900", "04. low": "33.0950", "05. price": "33.3400", "06. volume": "38952369", "07. latest trading day": "2023-06-26", "08. previous close": "33.0000", "09. change": "0.3400", "10. change percent": "1.0303%"}, "symbol": "INTC"}, "event": {"symbol": "INTC", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
symbol: INTC, Price: 33.3400, success True
symbol: INTU, Price: 453.3000, success True
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"INTU\",\n \"02. open\": \"451.6600\",\n \"03. high\": \"462.4200\",\n \"04. low\": \"451.6600\",\n \"05. price\": \"453.3000\",\n \"06. volume\": \"1418201\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"452.6900\",\n \"09. change\": \"0.6100\",\n \"10. change percent\": \"0.1348%\"\n }\n}", "event": {"symbol": "INTU", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "INTU", "02. open": "451.6600", "03. high": "462.4200", "04. low": "451.6600", "05. price": "453.3000", "06. volume": "1418201", "07. latest trading day": "2023-06-26", "08. previous close": "452.6900", "09. change": "0.6100", "10. change percent": "0.1348%"}, "symbol": "INTU"}, "event": {"symbol": "INTU", "function": "GLOBAL_QUOTE"}}
INFO:root:Found item in cache: None
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "response_from_alphavantage", "status_code": 200, "data": "{\n \"Global Quote\": {\n \"01. symbol\": \"AAPL\",\n \"02. open\": \"186.8300\",\n \"03. high\": \"188.0500\",\n \"04. low\": \"185.2300\",\n \"05. price\": \"185.2700\",\n \"06. volume\": \"48088661\",\n \"07. latest trading day\": \"2023-06-26\",\n \"08. previous close\": \"186.6800\",\n \"09. change\": \"-1.4100\",\n \"10. change percent\": \"-0.7553%\"\n }\n}", "event": {"symbol": "AAPL", "function": "GLOBAL_QUOTE"}}
INFO:root:{"method": "get_data_from_alpha_vantage", "action": "return_value", "data": {"success": true, "limit_reached": false, "status_code": 200, "Global Quote": {"01. symbol": "AAPL", "02. open": "186.8300", "03. high": "188.0500", "04. low": "185.2300", "05. price": "185.2700", "06. volume": "48088661", "07. latest trading day": "2023-06-26", "08. previous close": "186.6800", "09. change": "-1.4100", "10. change percent": "-0.7553%"}, "symbol": "AAPL"}, "event": {"symbol": "AAPL", "function": "GLOBAL_QUOTE"}}
symbol: AAPL, Price: 185.2700, success True
Process finished with exit code 0
Simple python wrapper around alpha vantage api, provide consistency across end points, debug easily and get the most out of your free account!