import os import openai import streamlit as st #from dotenv import load_dotenv # from streamlit_chat import message # 스트림릿이랑 파이썬, vs코드 같은 폴더에 # 이 파일도 같은 폴더에 넣어야하는지는 모르겠움,, # import streamlit as st # from io import StringIO # 경로 /Users/gyuribyun/Documents/legoapp # 경로 터미널에 입력 후(cd 경로 복붙) # streamlit run app.py로 링크 받기 # 타이틀 적용, # 특수 이모티콘 삽입 예시 # emoji: https://streamlit-emoji-shortcodes-streamlit-app-gwckff.streamlit.app/ st.title(':santa:레고스파이크 할아버지') # 캡션 적용 st.caption('레고스파이크 프라임을 이용한 코드를 구성할 때 어떤 블럭을 사용해야할 지 상황에 맞는 도움을 제공하는 친절한 레고할아버지 입니다. 선물:gift:같은 도움을 받아보세요!') # 마크다운 부가설명 st.markdown('###### openAI key를 입력하고, 코드가 필요한 상황, 작동 내용, 작동 조건, 입력장치, 출력장치를 각각 입력한다음 :red[코드블럭 추천받기] 버튼을 눌러주세요.:sparkles:') # api key api_key = st.text_input(label='openAI의 api key를 입력하세요.', placeholder='sk-...', type='password') if api_key: openai.api_key = api_key client = openai.Client(api_key = api_key) else: st.warning("유효한 API 키를 입력해 주세요.") client = None # client 변수를 None으로 초기화 if api_key: # 텍스트 입력 situation = st.text_input( label='무슨 상황인가요?', placeholder='예시: 자율주행' ) st.write(f'선택한 상황: :violet[{situation}]') # 텍스트 입력 condition = st.text_input( label='작동 조건이 있나요?', placeholder='예시: 벽에 닿음' ) st.write(f'선택한 상황: :violet[{condition}]') # 텍스트 입력 reaction = st.text_input( label='어떤 작동이 일어나야 하나요?', placeholder='예시: 모터 멈춤' ) st.write(f'선택한 상황: :violet[{reaction}]') # 텍스트 입력 input_sensor = st.text_input( label='입력 장치로 무엇을 사용하나요?', placeholder='예시: 거리 센서' ) st.write(f'선택한 상황: :violet[{input_sensor}]') # 텍스트 입력 output = st.text_input( label='출력 장치로 무엇을 사용하나요?', placeholder='예시: 모터' ) st.write(f'선택한 상황: :violet[{output}]') prompt = f'user:[상황- 금고 잠그기, 작동- 모터 돌리기, 조건- 프로그램이 시작될 때, 입력장치- 없음,출력장치- A모터, B모터], bot: [프로그램을 시작할 때, A모터 속도 설정, 지정된 시간만큼 A모터 작동, A모터를 위치로 이동, 상대 모터 위치를 설정, 부드러운 정지], user: [상황- 인식한 색에 따라 소리 내기, 작동- 효과음 재생, 조건- 노란색 인식, 입력장치- 컬러 센서, 출력장치- 스피커], bot: [허브 버튼을 누를 때, 조건 기다리기, 색상?, 재생하기], user: [상황- 힘센서를 눌러 집게 오므렸다 펴기, 작동- 모터 동작, 조건- 힘센서를 누르고 있을 때, 입력장치- 힘센서, 출력장치- 모터], bot:[프로그램을 시작할 때, 무한 루프, 만약 ~라면, 누름?, 모터 시동 출력, 아니면, 지정된 시간만큼 모터 작동, 모터 멈추기], user: [상황- 달리기 경주, 작동- 모터 동작, 조건- 프로그램 시작, 입력장치- 없음, 출력장치- 모터], bot: [프로그램을 시작할 때, 모터 동작 설정, 동작 속도 설정, 지정된 값만큼 이동], user: [상황- 벽에 부딪히면 멈추기, 작동- 모터 멈추기, 조건- 힘센서가 눌림, 입력장치- 힘센서, 출력장치- 모터], bot: [프로그램을 시작할 때, 무한 루프, 만약 ~라면, 누름?, 모터 시동, 아니면, 모터 멈추기], user: [상황- 밝기에 따라 불 끄고 켜기, 작동- 불 끄기, 조건- 밝음, 입력장치- 컬러센서, 출력장치- 라이트 매트릭스], bot: [프로그램을 시작할 때, 무한 루프, 만약 ~라면, 반사광?, 라이트 매트릭스 픽셀 밝기 설정 100. 아니면, 라이트 매트릭스 픽셀 밝기 설정 0], user: [상황- 허브가 흔들릴 때 라이트 픽셀 깜빡임, 흔들리지 않으면 멈추기, 작동- 라이트 픽셀 깜빡임, 조건- 허브 흔들림, 입력장치- 허브 자이로센서, 출력장치- 라이트 매트릭스], bot: [프로그램을 시작할 때, 무한 루프, 만약 ~라면, 허브 흔들림?, 라이트 매트릭스 픽셀 깜빡임, 아니면, 라이트 매트릭스 멈춤], user: [상황- {situation}, 작동- {reaction}, 조건- {condition}, 입력장치- {input_sensor}, 출력장치- {output}], bot' # 버튼 클릭 button = st.button(':gift:코드블럭 추천받기') if client: # client가 None이 아닌 경우에만 실행 def generate_recommend(prompt): completions = client.completions.create( model="gpt-3.5-turbo-instruct", prompt=prompt, temperature=0, max_tokens=400, top_p=1, frequency_penalty=0, presence_penalty=0 ) message = completions.choices[0].text.replace(",", " ] [ ") return message if button: output = generate_recommend(prompt) st.write(f'{output}')