heysho's picture
Update app.py
c7c6e0b verified
raw
history blame
2.13 kB
import traceback
import streamlit as st
from langchain_core.prompts import ChatPromptTemplate
from langchain_core.output_parsers import StrOutputParser
from langchain_openai import ChatOpenAI
from langchain_anthropic import ChatAnthropic
from langchain_google_genai import ChatGoogleGenerativeAI
PROMPT = """
次の文を修正してください。
出力言語は日本語です。
ここにテキストが入ります: {text}
"""
def init_page():
st.set_page_config(
page_title="エージェント",
page_icon="✍️"
)
st.header("文章校正AIエージェント ✍️")
def select_model(temperature=0):
models = ("GPT-4o","GPT-4o-mini", "Claude 3.5 Sonnet", "Gemini 1.5 Pro")
model_choice = st.radio("モデルを選ぶ:", models)
if model_choice == "GPT-4o":
return ChatOpenAI(temperature=temperature, model_name="gpt-4o")
elif model_choice == "GPT-4o-mini":
return ChatOpenAI(temperature=temperature, model_name="gpt-4o-mini")
elif model_choice == "Claude 3.5 Sonnet":
return ChatAnthropic(temperature=temperature, model_name="claude-3-5-sonnet-20240620")
elif model_choice == "Gemini 1.5 Pro":
return ChatGoogleGenerativeAI(temperature=temperature, model="gemini-1.5-pro-latest")
def init_chain():
llm = select_model()
prompt = ChatPromptTemplate.from_messages([
("user", PROMPT),
])
output_parser = StrOutputParser()
chain = prompt | llm | output_parser
return chain
def main():
init_page()
# Style adjustments (optional, remove if not needed)
st.markdown("""<style>.st-emotion-cache-15ecox0 { display: none !important; }
@media (max-width: 50.5rem) {.st-emotion-cache-13ln4jf {max-width: calc(0rem + 100vw);}}
</style>""",unsafe_allow_html=True,)
chain = init_chain()
if chain:
text = st.text_area("ここに日本語のテキストを入力してください:", key="text")
if st.button("テキストを校正する"):
result = chain.stream({"text": text})
st.write(result)
if __name__ == '__main__':
main()