-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathchatgpt.py
116 lines (99 loc) · 4.13 KB
/
chatgpt.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import tkinter as tk
from tkinter import messagebox
from openai import OpenAI
# Lista de modelos disponibles en OpenAI
AVAILABLE_MODELS = [
# Modelos originales
"gpt-4o-mini",
"gpt-4o",
"gpt-4",
"text-davinci-003",
"text-ada-001",
"text-babbage-001",
"text-curie-001",
"whisper-1",
"code-davinci-002",
"text-embedding-ada-002",
# Nuevos modelos
"gpt-4-turbo-preview",
]
class OpenAIApp:
def __init__(self, root):
self.root = root
self.root.title("OpenAI Chat App")
self.client = None
self.models = AVAILABLE_MODELS
self.conversation = []
self.max_tokens = 4000 # Default max tokens
self.setup_ui()
def setup_ui(self):
self.token_label = tk.Label(self.root, text="API Token:")
self.token_label.pack()
self.token_entry = tk.Entry(self.root, show="*")
self.token_entry.pack()
self.token_button = tk.Button(self.root, text="Set Token", command=self.set_token)
self.token_button.pack()
self.model_label = tk.Label(self.root, text="Model:")
self.model_label.pack()
self.model_var = tk.StringVar(self.root)
self.model_var.set(self.models[0]) # Set default model
self.model_dropdown = tk.OptionMenu(self.root, self.model_var, *self.models)
self.model_dropdown.pack()
self.token_limit_label = tk.Label(self.root, text="Max Tokens (4000 by default):")
self.token_limit_label.pack()
self.token_limit_entry = tk.Entry(self.root)
self.token_limit_entry.insert(0, "4000")
self.token_limit_entry.pack()
self.chat_log = tk.Text(self.root, state='disabled')
self.chat_log.pack()
self.message_entry = tk.Entry(self.root)
self.message_entry.pack()
self.send_button = tk.Button(self.root, text="Send", command=self.send_message)
self.send_button.pack()
def set_token(self):
api_key = self.token_entry.get()
self.client = OpenAI(api_key=api_key)
messagebox.showinfo("Info", "Token set successfully!")
def send_message(self):
if not self.client:
messagebox.showerror("Error", "API Token is not set!")
return
user_message = self.message_entry.get()
if not user_message:
messagebox.showerror("Error", "Message cannot be empty!")
return
self.conversation.append({"role": "user", "content": user_message})
try:
model = self.model_var.get()
max_tokens = int(self.token_limit_entry.get())
if model.startswith("gpt-"):
# Usar la API de chat para modelos GPT
response = self.client.chat.completions.create(
model=model,
messages=self.conversation,
max_tokens=max_tokens
)
assistant_message = response.choices[0].message.content
else:
# Usar la API de completions para modelos más antiguos
prompt = "\n".join([f"{m['role']}: {m['content']}" for m in self.conversation])
response = self.client.completions.create(
model=model,
prompt=prompt,
max_tokens=max_tokens
)
assistant_message = response.choices[0].text.strip()
self.conversation.append({"role": "assistant", "content": assistant_message})
self.update_chat_log(user_message, assistant_message)
except Exception as e:
messagebox.showerror("Error", f"Failed to send message: {str(e)}")
def update_chat_log(self, user_message, assistant_message):
self.chat_log.config(state='normal')
self.chat_log.insert(tk.END, f"You: {user_message}\n")
self.chat_log.insert(tk.END, f"Assistant: {assistant_message}\n")
self.chat_log.config(state='disabled')
self.message_entry.delete(0, tk.END)
if __name__ == "__main__":
root = tk.Tk()
app = OpenAIApp(root)
root.mainloop()