2019-11-23 18:24:06 +05:30
|
|
|
import requests
|
|
|
|
from bs4 import BeautifulSoup
|
|
|
|
|
|
|
|
|
|
|
|
def stock_price(symbol: str = "AAPL") -> str:
|
2023-08-10 20:22:35 +05:30
|
|
|
url = f"https://finance.yahoo.com/quote/{symbol}?p={symbol}"
|
|
|
|
yahoo_finance_source = requests.get(url,headers={'USER-AGENT': "Mozilla/5.0"}).text
|
|
|
|
soup = BeautifulSoup(yahoo_finance_source, "html.parser")
|
|
|
|
specific_fin_streamer_tag = soup.find('fin-streamer', {'data-test': 'qsp-price'})
|
2019-11-23 18:24:06 +05:30
|
|
|
|
2023-08-10 20:22:35 +05:30
|
|
|
if specific_fin_streamer_tag:
|
|
|
|
text = specific_fin_streamer_tag.get_text()
|
|
|
|
return text
|
2023-08-11 16:10:51 +05:30
|
|
|
return "No <fin-streamer> tag with the specified data-test attribute found."
|
2019-11-23 18:24:06 +05:30
|
|
|
|
2023-08-10 20:22:35 +05:30
|
|
|
# Search for the symbol at https://finance.yahoo.com/lookup
|
2019-11-23 18:24:06 +05:30
|
|
|
if __name__ == "__main__":
|
|
|
|
for symbol in "AAPL AMZN IBM GOOG MSFT ORCL".split():
|
|
|
|
print(f"Current {symbol:<4} stock price is {stock_price(symbol):>8}")
|