Robert Castagna commited on
Commit
024034d
·
1 Parent(s): 641a9e4

local env enhacements

Browse files
fin_data.db-journal ADDED
Binary file (29.2 kB). View file
 
pages/2_Portfolio_Builder.py CHANGED
@@ -24,11 +24,18 @@ def open_nested_event_loop():
24
  nest_asyncio.apply()
25
  try:
26
  loop = asyncio.get_event_loop()
 
27
  except RuntimeError as ex:
28
  if "There is no current event loop in thread" in str(ex):
29
  loop = asyncio.new_event_loop()
30
  asyncio.set_event_loop(loop)
 
31
  return
 
 
 
 
 
32
 
33
  def get_positions(account):
34
  positions = ib.portfolio(account)
@@ -65,36 +72,33 @@ load_dotenv()
65
 
66
  obb.account.login(pat=os.environ['open_bb_pat'])
67
 
68
- # -------------------------- (Tickers) -------------------------------- #
69
 
70
- if 'tickers' not in st.session_state:
71
- tickers = [
72
- "SPY", "QQQ","BND","GLD","VTI"
73
- ]
74
- st.session_state['tickers'] = tickers
75
-
76
- if not platform.processor(): # take inputs from the user for hosted application
77
- tickers = st.session_state['tickers']
78
-
79
- elif not re.search('AuthenticAMD', platform.processor()): # use live ibkr portfolio if ran from local machine
80
  try:
81
  # Initialize IB connection here
82
- open_nested_event_loop()
83
- from ib_insync import *
84
- ib = IB()
85
  # Assuming you're connecting to a local TWS instance with default settings
86
- ib.connect('127.0.0.1', 7497, clientId=1)
87
- paper_acct = ib.managedAccounts()[0]
88
-
89
  position_data = get_positions(paper_acct)
90
  for pos in position_data:
91
  tickers = [pos[0] for pos in position_data]
 
92
 
93
  except Exception as e:
94
  st.write('IB Workstation is not running. Please start the IB Workstation and try again.')
95
  st.write('Error: ', e)
96
  st.stop()
97
 
 
 
 
 
 
 
 
 
98
 
99
  list_of_tickers = get_list_of_tickers()
100
 
 
24
  nest_asyncio.apply()
25
  try:
26
  loop = asyncio.get_event_loop()
27
+ st.write("event loop exists")
28
  except RuntimeError as ex:
29
  if "There is no current event loop in thread" in str(ex):
30
  loop = asyncio.new_event_loop()
31
  asyncio.set_event_loop(loop)
32
+ st.write("event loop created")
33
  return
34
+
35
+ open_nested_event_loop()
36
+
37
+ from ib_insync import *
38
+
39
 
40
  def get_positions(account):
41
  positions = ib.portfolio(account)
 
72
 
73
  obb.account.login(pat=os.environ['open_bb_pat'])
74
 
75
+ # -------------------------------- (Tickers) -------------------------------- #
76
 
77
+ if re.search('AuthenticAMD', platform.processor()) and 'tickers' not in st.session_state: # use live ibkr portfolio if ran from local machine
 
 
 
 
 
 
 
 
 
78
  try:
79
  # Initialize IB connection here
80
+ with IB().connect('127.0.0.1', 7497, clientId=0, timeout=10) as ib:
 
 
81
  # Assuming you're connecting to a local TWS instance with default settings
82
+ paper_acct = ib.managedAccounts()[0]
83
+
 
84
  position_data = get_positions(paper_acct)
85
  for pos in position_data:
86
  tickers = [pos[0] for pos in position_data]
87
+ st.session_state.tickers = tickers
88
 
89
  except Exception as e:
90
  st.write('IB Workstation is not running. Please start the IB Workstation and try again.')
91
  st.write('Error: ', e)
92
  st.stop()
93
 
94
+ if 'tickers' not in st.session_state:
95
+ tickers = [
96
+ "SPY", "QQQ","BND","GLD","VTI"
97
+ ]
98
+ st.session_state['tickers'] = tickers
99
+
100
+ if not platform.processor(): # take inputs from the user for hosted application
101
+ tickers = st.session_state['tickers']
102
 
103
  list_of_tickers = get_list_of_tickers()
104
 
pages/3_Sentiment_Data_Input.py CHANGED
@@ -68,10 +68,11 @@ c.execute("""CREATE TABLE IF NOT EXISTS company_news (
68
  sentiment_score real
69
  )""")
70
 
 
 
 
71
 
72
- ticker = st.text_input(label='Entering ticker will add last 5 days of news sentiment data to database.')
73
-
74
- start_date_str = (datetime.datetime.today() - datetime.timedelta(days=5)).strftime('%Y-%m-%d')
75
  end_date_str = datetime.datetime.today().strftime('%Y-%m-%d')
76
  dates = set(pd.date_range(start=start_date_str, end=end_date_str).strftime('%Y-%m-%d'))
77
 
@@ -84,11 +85,19 @@ if st.button('Load') and ticker:
84
  unique_dates = dates - existing_dates
85
 
86
  if unique_dates:
 
87
  for date in unique_dates:
88
  try:
89
  res_news = get_finnhub_data(f"/company-news?symbol={ticker}&from={date}&to={date}")
90
  except:
91
- st.error('Invalid Ticker.')
 
 
 
 
 
 
 
92
  st.write(f"Proessing {len(res_news)} headlines for ", ticker,' on ', date)
93
 
94
  for item in res_news:
 
68
  sentiment_score real
69
  )""")
70
 
71
+ num_days_history=5
72
+ num_days_history = st.number_input(label='Number of Historical days to process. Beware of time.', value=5, min_value=1, max_value=30)
73
+ ticker = st.text_input(label=f'Entering ticker will add last {num_days_history} days of news sentiment data to database.')
74
 
75
+ start_date_str = (datetime.datetime.today() - datetime.timedelta(days=num_days_history)).strftime('%Y-%m-%d')
 
 
76
  end_date_str = datetime.datetime.today().strftime('%Y-%m-%d')
77
  dates = set(pd.date_range(start=start_date_str, end=end_date_str).strftime('%Y-%m-%d'))
78
 
 
85
  unique_dates = dates - existing_dates
86
 
87
  if unique_dates:
88
+ error_counter = 0
89
  for date in unique_dates:
90
  try:
91
  res_news = get_finnhub_data(f"/company-news?symbol={ticker}&from={date}&to={date}")
92
  except:
93
+ st.error('Data Source Error.')
94
+
95
+ if res_news == []:
96
+ error_counter += 1
97
+ if error_counter > 4:
98
+ st.error('Invalid Ticker.')
99
+ break
100
+
101
  st.write(f"Proessing {len(res_news)} headlines for ", ticker,' on ', date)
102
 
103
  for item in res_news: