heysho commited on
Commit
88daa8c
1 Parent(s): a919e8d

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +76 -0
app.py ADDED
@@ -0,0 +1,76 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import traceback
2
+ import streamlit as st
3
+ from langchain_core.prompts import ChatPromptTemplate
4
+ from langchain_core.output_parsers import StrOutputParser
5
+ from langchain_openai import ChatOpenAI
6
+ from langchain_anthropic import ChatAnthropic
7
+ from langchain_google_genai import ChatGoogleGenerativeAI
8
+
9
+ ###### dotenv を利用する場合 ######
10
+ try:
11
+ from dotenv import load_dotenv
12
+ load_dotenv()
13
+ except ImportError:
14
+ import warnings
15
+ warnings.warn("dotenv not found. Please make sure to set your environment variables manually.", ImportWarning)
16
+ ################################################
17
+
18
+
19
+ PROMPT = """
20
+ 次の文を修正してください。
21
+ 出力言語は日本語です。
22
+ ここにテキストが入ります: {text}
23
+ """
24
+
25
+ def init_page():
26
+ st.set_page_config(
27
+ page_title="テキスト校正AIエージェント",
28
+ page_icon="✍️"
29
+ )
30
+ st.header("テキスト校正AIエージェント ✍️")
31
+
32
+
33
+ def select_model(temperature=0):
34
+ models = ("GPT-4o","GPT-4o-mini", "Claude 3.5 Sonnet", "Gemini 1.5 Pro")
35
+ model_choice = st.radio("Choose a model:", models)
36
+ if model_choice == "GPT-4o":
37
+ return ChatOpenAI(temperature=temperature, model_name="gpt-4o")
38
+ elif model_choice == "GPT-4o-mini":
39
+ return ChatOpenAI(temperature=temperature, model_name="gpt-4o-mini")
40
+ elif model_choice == "Claude 3.5 Sonnet":
41
+ return ChatAnthropic(temperature=temperature, model_name="claude-3-5-sonnet-20240620")
42
+ elif model_choice == "Gemini 1.5 Pro":
43
+ return ChatGoogleGenerativeAI(temperature=temperature, model="gemini-1.5-pro-latest")
44
+
45
+ def init_chain():
46
+ llm = select_model()
47
+ prompt = ChatPromptTemplate.from_messages([
48
+ ("user", PROMPT),
49
+ ])
50
+ output_parser = StrOutputParser()
51
+ chain = prompt | llm | output_parser
52
+ return chain
53
+
54
+ def main():
55
+ init_page()
56
+ chain = init_chain()
57
+ if chain:
58
+ text = st.text_area("ここに日本語のテキストを入力してください:", key="text")
59
+ if st.button("テキストを校正する"):
60
+ result = chain.stream({"text": text})
61
+ st.write(result)
62
+
63
+
64
+ if __name__ == '__main__':
65
+ main()
66
+
67
+ # Style adjustments (optional, remove if not needed)
68
+ st.markdown(
69
+ """
70
+ <style>
71
+ /* Custom style adjustments */
72
+ .st-emotion-cache-iiif1v { display: none !important; }
73
+ </style>
74
+ """,
75
+ unsafe_allow_html=True,
76
+ )