JoanParanoid's picture
Update app.py
186083d verified
raw
history blame
1.81 kB
import streamlit as st
from transformers import pipeline
def analyze_financial_news():
access = "hf_"
token = "hhbFNpjKohezoexWMlyPUpvJQLWlaFhJaa"
# Load the text classification model pipeline
classification = pipeline("text-classification", model="nickmuchi/finbert-tone-finetuned-finance-topic-classification", token=access+token)
sentiment_analysis = pipeline("sentiment-analysis")
st.set_page_config(page_title="Financial News Analysis", page_icon="β™•")
# Streamlit application layout
st.title("Financial News Analysis")
st.write("Analyze corresponding Topic and Trend for Financial News!")
st.image("./Fin.jpg", use_column_width=True)
# Text input for user to enter the text
text = st.text_area("Enter the Financial News", "")
analyze_clicked = st.button("Analyze")
if analyze_clicked:
# Perform text classification on the input text
results = classification(text)
# Filter only the news related to "Energy | Oil"
energy_oil_news = [news for news in results if news["label"] == "Energy | Oil"]
if energy_oil_news:
# If there are news related to "Energy | Oil", perform sentiment analysis for each news
for news in energy_oil_news:
sentiment_results = sentiment_analysis(news["sequence"])[0]
# Display the sentiment analysis result for each news
st.write("Original Text:", news["sequence"])
st.write("Sentiment:", sentiment_results["label"])
st.write("Sentiment Score:", sentiment_results["score"])
st.write("---")
else:
st.write("No news relevant to Energy | Oil.")
def main():
analyze_financial_news()
if __name__ == "__main__":
main()