from pandasai.llm import GoogleGemini import streamlit as st import os import pandas as pd from pandasai import SmartDataframe from pandasai.responses.response_parser import ResponseParser class StreamLitResponse(ResponseParser): def __init__(self,context) -> None: super().__init__(context) def format_dataframe(self,result): st.dataframe(result['value']) return def format_plot(self,result): st.image(result['value']) return def format_other(self, result): st.write(result['value']) return gemini_api_key = os.environ['Gemini'] def generateResponse(dataFrame,prompt): llm = GoogleGemini(api_key=gemini_api_key) pandas_agent = SmartDataframe(dataFrame,config={"llm":llm, "response_parser":StreamLitResponse}) answer = pandas_agent.chat(prompt) return answer st.write("# Brave Retail Insights") st.write("##### Engage in insightful conversations with your data through powerful visualizations") with st.sidebar: st.title("Brave Retail Insights") # Added a divider st.divider() # Add content to the sidebar/drawer with st.expander("Data Visualization"): st.write("
Developed by - Rairo
",unsafe_allow_html=True) uploaded_file = "ok_customers.csv" if uploaded_file is not None: # Read the CSV file df = pd.read_csv(uploaded_file) # Display the data with st.expander("Preview"): st.write(df.head()) # Plot the data user_input = st.text_input("Type your message here",placeholder="Ask me about your data") if user_input: answer = generateResponse(dataFrame=df,prompt=user_input) st.write(answer)