Spaces:
Sleeping
Sleeping
import streamlit as st | |
import openai | |
import json | |
import os | |
import pandas as pd | |
# OpenAI API μ€μ (νκ²½ λ³μμμ μ½μ΄μ΄) | |
openai.api_key = os.getenv("OPENAI_API_KEY") | |
# μ±μ·¨κΈ°μ€ λ°μ΄ν° κ°μ Έμ€κΈ° | |
import achievement_standards as data | |
achievement_standards = data.achievement_standards | |
# gptμ΄μ©ν΄μ μΆλ‘ ν¨μ λ§λ€κΈ° | |
def generate_annotated_text(text): | |
response = openai.ChatCompletion.create( | |
model="gpt-3.5-turbo-16k", | |
messages=[ | |
{ | |
"role": "system", | |
"content": "μ±μ·¨κΈ°μ€ κΈ°λ° νμμ νΉμ± λ° νλ νκ° μμ±\nμ±μ·¨κΈ°μ€μ μ λ ₯νμλ©΄, ν΄λΉ μ±μ·¨κΈ°μ€μ κΈ°λ°ν νμμ νΉμ± λ° νλμ λν νκ°λ₯Ό annotated_text νμμΌλ‘ μ 곡ν©λλ€. μ±μ·¨κΈ°μ€μ 보며 νμμ νΉμ νλ, μ±μ·¨ μμ€, κ΅μ¬μ μ΄ν, κ·Έλ¦¬κ³ νμμ μλμ κ³ λ €νμ¬ μ²΄κ³μ μΌλ‘ ꡬμ±λ μΆλ ₯μ μ 곡ν©λλ€. μ£Όμ΄λ λ°λμ μλ΅ν©λλ€. \n\nμμ :\nμ λ ₯: ```μ±μ·¨κΈ°μ€: [6κ΅01-07]μλκ° μ²ν μν©μ μ΄ν΄νκ³ κ³΅κ°νλ©° λ£λ νλλ₯Ό μ§λλ€, [6κ΅01-02] μ견μ μ μνκ³ ν¨κ» μ‘°μ νλ©° ν μνλ€.```\nμΆλ ₯: ```annotated_text(\n (\"νμ μμ μ μκ°μ μΌλͺ©μμ°νκ² μ 리νλ μ΅κ΄μ΄ μμ.\", \"μλ\", \"rgba(255, 0, 0, 0.3)\"),\n (\"μ¬ν νμμ κ΄ν μ£Όμ₯νλ κΈμ°κΈ°λ₯Ό μν¨.\", \"μ±μ·¨μμ€\", \"rgba(0, 0, 255, 0.3)\"),\n (\"μΉκ΅¬μ κ³ λ―Όμ ν΄κ²°ν΄μ£Όλ μν κ·Ήμμ μλλ°©μ λ°°λ €νμ¬ ν΄κ²° κ°λ₯ν λ°©μμ μ μν¨.\", \"μν\", \"rgba(0, 128, 0, 0.3)\"),\n (\"μλκ° μ²ν μν©μ μ΄ν΄νκ³ κ³΅κ°νλ νλλ₯Ό κ°μ§κ³ μΉκ΅¬λ€κ³Ό μλ§ν κ΄κ³λ₯Ό λ§Ίκ³ κ°λ±μ μ‘°μ ν¨.\", \"κ΅μ¬μ΄ν\", \"rgba(128, 128, 128, 0.3)\"),\n (\"μ€κ° λμ΄ μκ°μ μ΄λμ₯μ μ¬μ©νλ λ°©λ² μ νκΈ°λ₯Ό μ£Όμ λ‘ ν ν μμμ μλ§μ κ·Όκ±°μ λ·λ°μΉ¨ν μ μλ μλ£λ₯Ό ν λλ‘ μμ μ μ견μ νλΉνκ² μ μνλ©΄μ λ€λ₯Έ μ¬λμ μ견μ λ₯λμ μΌλ‘ μμ©νκ³ ν¨κ³Όμ μΌλ‘ μ견μ μ‘°μ νλ λ₯λ ₯μ 보μ.\", \"μν\", \"rgba(0, 128, 0, 0.3)\"),\n (\"μλμ μ견μ μ‘΄μ€νκ³ νλ ₯νλ νλλ₯Ό 보μ.\", \"μλ\", \"rgba(255, 0, 0, 0.3)\")\n)\n```" | |
}, | |
{ | |
"role": "user", | |
"content": text | |
} | |
], | |
temperature=1, | |
max_tokens=10000, | |
top_p=1, | |
frequency_penalty=0, | |
presence_penalty=0 | |
) | |
return response['choices'][0]['message']['content'] | |
# μ μ¬ν λ¬Έμ₯ μμ± ν¨μ | |
def generate_similar_sentences(base_sentence): | |
response = openai.ChatCompletion.create( | |
model="gpt-3.5-turbo-16k", | |
messages=[ | |
{ | |
"role": "system", | |
"content": f"λ€μμ '{base_sentence}'μ μ μ¬ν νμμ νΉμ± λ° νλμ λν νκ° μμ λ¬Έν 10κ°λ₯Ό λ§λ€μ΄λΌ. μ£Όμ΄λ μλ΅ν΄λΌ. λ¬Έμ₯μ λμ '~μ,~ν¨,~μ'μΌλ‘ λλλλ‘ ν΄μ€" | |
}, | |
{ | |
"role": "user", | |
"content": base_sentence | |
} | |
], | |
temperature=0.7, | |
max_tokens=10000, | |
top_p=1, | |
frequency_penalty=0, | |
presence_penalty=0 | |
) | |
generated_sentences = response.choices[0].message['content'].split('\n') | |
return [sentence.strip() for sentence in generated_sentences if sentence.strip()] | |
# Streamlit μ±μ μ λͺ© λ° μ€λͺ | |
st.title("μ±μ·¨κΈ°μ€ κΈ°λ° νμμ νΉμ± λ° νλ νκ° μμ±") | |
st.write("μ±μ·¨κΈ°μ€μ μ λ ₯νμλ©΄, ν΄λΉ μ±μ·¨κΈ°μ€μ κΈ°λ°ν νμμ νΉμ± λ° νλμ λν νκ°λ₯Ό [νμ νλ, μ±μ·¨ μμ€, κ΅μ¬μ μ΄ν, νμ μλ] 4κ°μ§ μμλ₯Ό μ‘°ν©νμ¬ μ 곡ν©λλ€.") | |
# νλ κ΅° μ ν λλ‘λ€μ΄ | |
grade_group = st.selectbox("νλ κ΅°μ μ ννμΈμ:", list(achievement_standards.keys())) | |
# μ νλ νλ κ΅°μ λ°λ₯Έ κ³Όλͺ© λͺ©λ‘ | |
subject_list = list(achievement_standards[grade_group].keys()) | |
subject = st.selectbox("κ³Όλͺ©μ μ ννμΈμ:", subject_list) | |
# μ νλ κ³Όλͺ©μ λ°λ₯Έ μ±μ·¨κΈ°μ€ λͺ©λ‘ | |
selected_standards = achievement_standards[grade_group][subject] | |
selected_standard = st.selectbox("μ±μ·¨κΈ°μ€μ μ ννμΈμ:", selected_standards) | |
# μ νλ μ±μ·¨κΈ°μ€μ ν μ€νΈ μ λ ₯μ°½μ κΈ°λ³Έκ°μΌλ‘ μ¬μ© | |
achievement_standard = st.text_input("μ±μ·¨κΈ°μ€ μ λ ₯:", value=selected_standard) | |
# μΈμ μν μ΄κΈ°ν | |
if 'generated_result' not in st.session_state: | |
st.session_state.generated_result = None | |
if 'selected_sentence' not in st.session_state: | |
st.session_state.selected_sentence = None | |
if 'similar_sentences' not in st.session_state: | |
st.session_state.similar_sentences = [] | |
# "νκ° μμ±" λ²νΌ ν΄λ¦ μμ λμ | |
if st.button("νκ° μμ±"): | |
with st.spinner('λ΅λ³ μμ±μ€...'): | |
result = generate_annotated_text(achievement_standard) | |
st.session_state.generated_result = result | |
st.session_state.selected_sentence = None # μλ‘μ΄ νκ° μμ±μ μ νλ λ¬Έμ₯ μ΄κΈ°ν | |
st.session_state.similar_sentences = [] # μ΄μ μ μ¬ν λ¬Έμ₯λ€ μ΄κΈ°ν | |
exec(result.replace('```', '')) | |
# μ λ νΈ λ°μ€ λ° μ μ¬ν λ¬Έμ₯ μμ± λ²νΌ μΆκ° | |
if st.session_state.generated_result: | |
# annotated_text κ²°κ³Όμμ λ¬Έμ₯λ§ μΆμΆ | |
result_lines = st.session_state.generated_result.split('\n') | |
sentences = [line[start_idx + 2:line.find('",', start_idx)].strip() for line in result_lines if (start_idx := line.find('("')) != -1] | |
if sentences: | |
selected_sentence = st.selectbox("λ¬Έμ₯μ μ ννμΈμ:", sentences, key="sentence_select") | |
st.session_state.selected_sentence = selected_sentence | |
# μ μ¬ν λ¬Έμ₯ μμ± λ²νΌ | |
if st.button("μ μ¬ν 문ꡬ μμ±") and st.session_state.selected_sentence: | |
with st.spinner('λ¬Έμ₯ μμ±μ€...'): | |
st.session_state.similar_sentences = generate_similar_sentences(st.session_state.selected_sentence) | |
# μ μ¬ν λ¬Έμ₯λ€ μΆλ ₯ | |
for sentence in st.session_state.similar_sentences: | |
st.write(sentence) | |
# CSV μ μ₯ λ²νΌ μΆκ° | |
if st.session_state.similar_sentences: | |
if st.button("CSVλ‘ μ μ₯"): | |
df = pd.DataFrame(st.session_state.similar_sentences, columns=["Evaluation"]) | |
df.to_csv("evaluations.csv", index=False) | |
st.success("CSV νμΌμ΄ μ μ₯λμμ΅λλ€.") | |
with open("evaluations.csv", "rb") as file: | |
btn = st.download_button( | |
label="CSV λ€μ΄λ‘λ", | |
data=file, | |
file_name="evaluations.csv", | |
mime="text/csv" | |
) | |