TelegramAktienBot/telegram_bot/shares/share_fetcher.py

120 lines
4.1 KiB
Python
Raw Normal View History

2022-03-15 07:55:12 +00:00
"""
script for share fetching (by symbols (e.g. AAPL, TSLA etc.))
"""
__author__ = "Florian Kellermann, Linus Eickhoff"
2022-05-10 15:37:20 +00:00
__date__ = "10.05.2022"
__version__ = "1.0.1"
__license__ = "None"
import investpy
import pandas
from currency_converter import CurrencyConverter
def get_share_price(str_search_for):
2022-05-07 17:34:54 +00:00
"""get stock price per share for company name or isin or symbol
Args:
2022-05-07 17:38:17 +00:00
str_search_for (string): search for this string/isin
2022-05-07 17:38:17 +00:00
Returns: none
"""
try:
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'], n_results=1, countries=['germany'])
currency = str(search_result.retrieve_currency())
recent_data = pandas.DataFrame(search_result.retrieve_recent_data())
stock_price = recent_data.iloc[-1]["Close"]
stock_price = round(float(stock_price), 2)
str_return =str(stock_price) + " " + str(currency)
return str_return
except RuntimeError:
try:
my_Converter = CurrencyConverter()
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'], n_results=1)
currency = str(search_result.retrieve_currency())
recent_data = pandas.DataFrame(search_result.retrieve_recent_data())
stock_price = recent_data.iloc[-1]["Close"]
stock_price = my_Converter.convert(float(stock_price), str(currency), 'EUR')
stock_price = round(float(stock_price), 2)
str_return =str(stock_price) + " EUR"
return str_return
except RuntimeError:
return "None"
2022-05-07 17:33:02 +00:00
def get_share_price_no_currency(str_search_for):
2022-05-07 17:38:17 +00:00
"""get stock price per share for company name or isin or symbol no currency
2022-05-07 17:33:02 +00:00
Args:
2022-05-07 17:38:17 +00:00
str_search_for (string): search for this string/isin
Returns: none
2022-05-07 17:33:02 +00:00
"""
try:
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'],
countries=['germany'], n_results=1)
recent_data = pandas.DataFrame(search_result.retrieve_recent_data())
stock_price = recent_data.iloc[-1]["Close"]
stock_price = round(float(stock_price), 2)
return stock_price
2022-05-07 17:33:02 +00:00
except RuntimeError:
my_Converter = CurrencyConverter()
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'], n_results=1)
currency = str(search_result.retrieve_currency())
2022-05-07 17:33:02 +00:00
recent_data = pandas.DataFrame(search_result.retrieve_recent_data())
stock_price = recent_data.iloc[-1]["Close"]
stock_price = my_Converter.convert(float(stock_price), str(currency), 'EUR')
stock_price = round(float(stock_price), 2)
str_return =str(stock_price)
2022-05-07 17:33:02 +00:00
return str_return
2022-05-07 17:33:02 +00:00
def get_share_information(str_search_for):
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'],
countries=['germany'], n_results=1)
str_return = "Company: " + search_result.name + "\nSymbol: " + search_result.symbol + "\nCurrent Price/Share: " + get_share_price(str_search_for)
return str_return
def get_share_information_markdown(str_search_for):
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'],
countries=['germany'], n_results=1)
str_return = f'*{search_result.name}*\n_{search_result.symbol}_\nworth: {get_share_price(str_search_for)}'
return str_return
def get_share_information_simple(str_search_for):
search_result = investpy.search_quotes(text=str_search_for, products=['stocks'],
countries=['germany'], n_results=1)
str_return = search_result.name + "\n" +search_result.symbol + "\nworth: " + get_share_price(str_search_for)
return str_return
if __name__ == "__main__":
print("None")