2019-11-23 20:54:06 +08:00
|
|
|
import requests
|
|
|
|
from bs4 import BeautifulSoup
|
|
|
|
|
|
|
|
|
|
|
|
def stock_price(symbol: str = "AAPL") -> str:
|
2023-08-13 05:58:37 +08:00
|
|
|
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 20:54:06 +08:00
|
|
|
|
2023-08-13 05:58:37 +08:00
|
|
|
if specific_fin_streamer_tag:
|
|
|
|
text = specific_fin_streamer_tag.get_text()
|
|
|
|
return text
|
|
|
|
return "No <fin-streamer> tag with the specified data-test attribute found."
|
2019-11-23 20:54:06 +08:00
|
|
|
|
2023-08-13 05:58:37 +08:00
|
|
|
|
|
|
|
# Search for the symbol at https://finance.yahoo.com/lookup
|
2019-11-23 20:54:06 +08:00
|
|
|
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}")
|