SaaS_project / app.py
abaliyan's picture
Upload app.py
f8fecf8 verified
raw
history blame contribute delete
No virus
2.89 kB
from langchain.chains import LLMChain
from langchain_community.llms import OpenAI
from langchain_core.prompts import PromptTemplate
import streamlit as st
# Set the page to wide mode
st.set_page_config(layout="wide")
mini_template = "You are an expert researcher. You\'ve talked to hundreds of {Target Audience}. \
Each person in the niche of {Target Audience} has certain struggles that make it easier to sell {My Course}. \
These are called Pain Points. There's a recipe for getting to the core of the Pain Points of {Target Audience}. \
Namely, answer each of these Questions 3 times, each getting deeper in the issues of {Target Audience}, \
appealing to their Emotions and uncertainties related to {My Course}. \
The Questions (answer each QUESTION 3 times in listicle format according to the instructions):\
1. What keeps them awake at night?\
2. What are they afraid of?\
3. What are they angry about?\
"
st.title("Saas Application")
prompt = PromptTemplate(
input_variables = ["Target Audience", "My Course"],
template=mini_template,
)
chain = LLMChain(llm=OpenAI(), prompt=prompt)
#target_audience = "professionals looking for course on Power BI"
#my_course = "Zero to Hero in PowerBI"
# Use the sidebar for input
target_audience = st.sidebar.text_input("Enter your target audience")
my_course = st.sidebar.text_input("Enter your course name")
if st.sidebar.button("Get response"):
if target_audience and my_course:
with st.spinner("Generating response..."):
with st.expander("Show prompt", expanded=False):
st.info(prompt.template)
answer = chain.run({"Target Audience": target_audience, "My Course": my_course})
# Split the 'answer' into sections based on the questions
sections = [section.strip() for section in answer.split("\n\n") if section.strip() != ""]
# Assuming there are exactly three sections based on your output structure
if len(sections) == 3:
# Extract titles for tabs
titles = [section.split('\n')[0] for section in sections]
# Extract content for each section, removing the title
contents = [section.split('\n')[1:] for section in sections]
# Create tabs for each category
tabs = st.tabs(titles)
for i, tab in enumerate(tabs):
with tab:
st.header(titles[i])
for content in contents[i]:
st.markdown(content)
else:
st.error("The answer format does not match the expected structure.")
st.success("Hope you like the response.❤")
elif target_audience:
st.error("Enter your course name.")
elif my_course:
st.error("Enter your target audience.")
else:
st.error("No input detected, Please provide the desired information.")