-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
98 lines (85 loc) · 3.02 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
import openai
from dotenv import find_dotenv, load_dotenv
import time
import logging
from datetime import datetime
load_dotenv()
# Add api key if not work with methods below
#1) openai.api_key = os.environ.get("OPENAI_API_KEY")
#2) client = OpenAI(
# api_key=os.enviorn.get("OPENAI_API_KEY"),
#)
client = openai.OpenAI()
model = "gpt-3.5-turbo-1106"
# #=== Create our Assistant ===#
# personal_trainer_assis = client.beta.assistants.create(
# name="Personal Trainer",
# instructions=""" You are the best personal trainer and nutritionist. You've trained high-caliber athletes and movie stars. """,
# model=model
# )
# assistant_id = personal_trainer_assis.id
# print(assistant_id)
#=== Thread ===#
# thread = client.beta.threads.create(
# messages=[
# {
# "role": "user",
# "content": "How do I get started working out to lose fat and build muscles?"
# }
# ]
# )
# thread_id = thread.id
# print(thread_id)
# === Hardcode our ids ===
assistant_id = "asst_vkixZZFtR8Gx9T4a5NIqpM1y"
thread_id = "thread_NILtGMVU4FBDLH1XzuAcKPi9"
# === Create a message ===
message = "How many reps do I need to do to build lean muscles?"
message = client.beta.threads.messages.create(
thread_id=thread_id,
role="user",
content=message
)
# === Run our Assistant ==
run = client.beta.threads.runs.create(
thread_id=thread_id,
assistant_id=assistant_id,
instructions="Please address the user as Devtommie"
)
def wait_for_run_completion(client, thread_id, run_id, sleep_interval=5):
"""
Waits for a run to complete and prints the elapsed time.
:param client: The client
:param thread_id: The ID of the thread.
:param run_id: The ID of the run.
:param sleep_interval: Time in seconds to wait between checks.
"""
while True:
try:
run = client.beta.threads.runs.retrieve(thread_id=thread_id, run_id=run_id)
if run.completed_at:
elapsed_time = run.completed_at - run.created_at
formatted_elapsed_time = time.strftime(
"%H:%M:%S", time.gmtime(elapsed_time)
)
print(f"Run completed in {formatted_elapsed_time}")
logging.info(f"Run completed in {formatted_elapsed_time}")
# Get messages here once Run is completed
messages = client.beta.threads.messages.list(thread_id=thread_id)
last_message = messages.data[0]
response = last_message.content[0].text.value
print(f"Assistant Response: {response}")
break
except Exception as e:
logging.error(f"An error occurred while retrieving the run: {e}")
break
logging.info("Waiting for run to complete...")
time.sleep(sleep_interval)
# === Run ===
wait_for_run_completion(client=client, thread_id=thread_id, run_id=run.id)
# === Steps --- Logs ===
run_steps = client.beta.threads.runs.steps.list(
thread_id=thread_id,
run_id=run.id
)
print(f"Steps----> {run_steps.data}")