PyQt OpenAI example
Project description
pyqt-openai
Example of using OpenAI with PyQt (Python cross-platform GUI toolkit)
This shows an example of using OpenAI with PyQt as a chatbot.
Even though this project has become too huge to be called an 'example'.
The major advantage of this package is that you don't need to know other language aside from Python.
If you want to study openai with Python-only good old desktop software, this is for you.
The OpenAI model this package uses is the gpt-3.5-turbo model(which is nearly as functional as ChatGPT) by default. You can use gpt-4 as well.
Image generation feature available since v0.0.16. You can see the detail in official OpenAI site. Currently this feature is very basic now.
This is using sqlite as a database.
You can select the model at the right side bar.
An internet connection is required.
Contact
You can join pyqt-openai's Discord Server to have a conversation about it or AI-related stuff 🙂
Note
Some of the features are still being tested.
Feature
-
basically this is desktop application version of ChatGPT
-
text streaming (enable by default, you can disable it)
-
AI remembers past conversation
-
-
support GPT-4
-
you can save the conversation history with sqlite database
-
support prompt generator
-
support image generation with DALL-E
-
you can test any models, including gpt3.5
-
you can run this in background application
-
you can make window stack on top or control its transparency
Requirements
-
qtpy - the package allowing you to write code that works with both PyQt and PySide
-
PyQt5 >= 5.14 or PySide6
-
openai
Preview
This is using GPT-3.5 turbo model by default.
Homepage
You have to write your openai api key inside the red box. see How to play
Overview
Conversation preview
Preview Image
Preview Video
Prompt Generator
So sorry to weak preview, but i have a lot of idea about this prompt generator! Just wait.
How to play
-
git clone ~
-
from the root directory, type "cd pyqt_openai"
-
You should put your api key in the line edit. You can get it in official site of openai. Sign up and log in before you get it. By the way, this is free trial, not permanently free. See this after you have logged in.
Be sure, this is a very important API key that belongs to you only, so you should remember it and keep it secure.
- python main.py
If installation doesn't work, check the troubleshooting below.
Troubleshooting
If you see this error while installing the openai package
subprocess-exited-with-error
you can shout a curse word and just download the package itself from pypi.
Unzip it, access the package directory, type
python setup.py install
That will install the openai.
TODO list
-
support Stable Diffusion
-
show the explanation of every model and terms related to AI (e.g. temperature, topp..)
-
save conversation history with other format (xlsx, csv, etc.)
-
tokenizer
-
highlight the source (optional, eventually)
-
support multiple language
-
use SQLAlchemy (maybe not)
-
show reason when the chat input is disabled for some reasons
-
add the basic example sources of making deep learning model with PyTorch (eventually)
See Also
-
join gpt4 waitlist - i took 1 month to get access from it
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pyqt-openai-0.1.21.tar.gz
.
File metadata
- Download URL: pyqt-openai-0.1.21.tar.gz
- Upload date:
- Size: 44.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7aba3b749168efaca8dbf9bc1f5c2e2829304372bbdafd1d8f3ffa726976dcd0 |
|
MD5 | e0b898423ab25abd53791e4738e1d948 |
|
BLAKE2b-256 | 2feaa308a4007c6f41f9b3a9e13fcd72f832f76c8fae0362fab0583206db8f24 |
File details
Details for the file pyqt_openai-0.1.21-py3-none-any.whl
.
File metadata
- Download URL: pyqt_openai-0.1.21-py3-none-any.whl
- Upload date:
- Size: 54.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c67248222c7aaa98469fd9652d27fc29dac7b76961e7a302a1f1a03eafcaaad5 |
|
MD5 | 1fbf61e10db33dd74a6501c4842e8d67 |
|
BLAKE2b-256 | 490ad80bba6bd5c359de25a492bd4ae373fe8534d0f03314dc68bfd67eaaf7ba |