Python調(diào)用ChatGPT的API實(shí)現(xiàn)文章生成
實(shí)操目標(biāo)
最近ChatGPT大火,在3.5版本后開(kāi)放了接口API,所以很多人開(kāi)始進(jìn)行實(shí)操,這里我就用python來(lái)為大家實(shí)現(xiàn)一下,如何調(diào)用API并提問(wèn)返回文章的說(shuō)明
實(shí)操內(nèi)容
獲取API
書(shū)寫python調(diào)用框架
封裝到pyqt中,實(shí)現(xiàn)UI化
封裝為exe
具體操作
話不多說(shuō),直接上代碼
import sys
import openai
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QHBoxLayout, QLabel, QLineEdit, QPushButton, QSpinBox
from PyQt5.QtCore import QThread, pyqtSignal
class ChatThread(QThread):
response_ready = pyqtSignal(str)
def __init__(self, prompt, num_threads):
super().__init__()
self.prompt = prompt
self.num_threads = num_threads
def run(self):
openai.api_key = "這里輸入你的API"
response = openai.Completion.create(
engine="text-davinci-003",
prompt=self.prompt,
max_tokens=1024,
temperature=0.5,
top_p=1.0,
frequency_penalty=0.0,
presence_penalty=0.0,
n=self.num_threads
)
self.response_ready.emit(response.choices[0].text.strip())
class ChatWindow(QWidget):
def __init__(self):
super().__init__()
# 設(shè)置窗口標(biāo)題和大小
self.setWindowTitle('Chat with GPT-3')
self.resize(500, 400)
# 創(chuàng)建一個(gè)垂直布局,并將所有控件添加到布局中
layout = QVBoxLayout()
# 創(chuàng)建一個(gè)標(biāo)簽,并添加到布局中
label = QLabel('Please enter your question:')
layout.addWidget(label)
# 創(chuàng)建一個(gè)文本框,并添加到布局中
self.text_edit = QLineEdit()
layout.addWidget(self.text_edit)
# 創(chuàng)建一個(gè)水平布局,并添加一個(gè)按鈕和一個(gè)標(biāo)簽
hbox = QHBoxLayout()
self.button = QPushButton('Ask')
self.button.clicked.connect(self.on_button_clicked)
hbox.addWidget(self.button)
# 創(chuàng)建一個(gè)SpinBox控件,用于選擇線程數(shù)量
self.thread_spinbox = QSpinBox()
self.thread_spinbox.setMinimum(1)
self.thread_spinbox.setMaximum(10)
self.thread_spinbox.setValue(1)
hbox.addWidget(self.thread_spinbox)
self.answer_label = QLabel()
hbox.addWidget(self.answer_label)
layout.addLayout(hbox)
# 設(shè)置窗口的主布局
self.setLayout(layout)
def on_button_clicked(self):
# 從文本框中獲取問(wèn)題
prompt = self.text_edit.text()
# 獲取選中的線程數(shù)量
num_threads = self.thread_spinbox.value()
# 創(chuàng)建并啟動(dòng)線程
thread = ChatThread(prompt, num_threads)
thread.response_ready.connect(self.on_response_ready)
thread.start()
def on_response_ready(self, response):
# 將答案顯示在標(biāo)簽中
self.answer_label.setText(response)
if __name__ == '__main__':
# 創(chuàng)建一個(gè)Qt應(yīng)用對(duì)象
app = QApplication(sys.argv)
# 創(chuàng)建一個(gè)窗口對(duì)象
window = ChatWindow()
# 顯示窗口
window.show()
# 運(yùn)行Qt應(yīng)用的主循環(huán)
sys.exit(app.exec_())
'''
import sys
import openai
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QHBoxLayout, QLabel, QLineEdit, QPushButton
from PyQt5.QtCore import Qt
class ChatWindow(QWidget):
def __init__(self):
super().__init__()
# 設(shè)置窗口標(biāo)題和大小
self.setWindowTitle('小杰巨無(wú)霸gpt自動(dòng)生成器')
self.resize(500, 400)
# 創(chuàng)建一個(gè)垂直布局,并將所有控件添加到布局中
layout = QVBoxLayout()
# 創(chuàng)建一個(gè)標(biāo)簽,并添加到布局中
label = QLabel('請(qǐng)?jiān)谙路捷斎肽膯?wèn)題:')
label.setStyleSheet('font-size: 18pt; color: #006699; font-family: SimSun')
label.setAlignment(Qt.AlignCenter)
layout.addWidget(label)
# 創(chuàng)建一個(gè)文本框,并添加到布局中
self.text_edit = QLineEdit()
self.text_edit.setStyleSheet('font-size: 14pt; font-family: SimSun')
layout.addWidget(self.text_edit)
# 創(chuàng)建一個(gè)水平布局,并添加一個(gè)按鈕和一個(gè)標(biāo)簽
hbox = QHBoxLayout()
self.button = QPushButton('開(kāi)始生成')
self.button.setStyleSheet('font-size: 16pt; font-family: SimSun; color: white; background-color: #006699')
self.button.clicked.connect(self.on_button_clicked)
hbox.addWidget(self.button)
self.answer_label = QLabel()
self.answer_label.setStyleSheet('font-size: 14pt; color: #006699; font-family: SimSun')
self.answer_label.setAlignment(Qt.AlignCenter)
hbox.addWidget(self.answer_label)
layout.addLayout(hbox)
hbox.setAlignment(Qt.AlignCenter)
# 設(shè)置窗口的主布局
self.setLayout(layout)
# 初始化OpenAI API
openai.api_key = "這里輸入你獲取的KEY"
def on_button_clicked(self):
# 從文本框中獲取問(wèn)題
prompt = self.text_edit.text()
# 使用OpenAI API獲取答案
response = openai.Completion.create(
engine="text-davinci-003",
prompt=prompt,
max_tokens=1024,
temperature=0.5,
top_p=1.0,
frequency_penalty=0.0,
presence_penalty=0.0
)
# 將答案顯示在標(biāo)簽中
self.answer_label.setText(response.choices[0].text.strip())
if __name__ == '__main__':
# 創(chuàng)建一個(gè)Qt應(yīng)用對(duì)象
app = QApplication(sys.argv)
# 創(chuàng)建一個(gè)窗口對(duì)象
window = ChatWindow()
# 顯示窗口
window.show()
# 運(yùn)行Qt應(yīng)用的主循環(huán)
sys.exit(app.exec_())
成品展示
UI界面比較簡(jiǎn)單,有興趣的伙伴可以深化美化一番。
直接輸入問(wèn)題,就可以生成答案!

到此這篇關(guān)于Python調(diào)用ChatGPT的API實(shí)現(xiàn)文章生成的文章就介紹到這了,更多相關(guān)Python ChatGPT生成文章內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python表格數(shù)據(jù)處理庫(kù)之tablib庫(kù)詳解
這篇文章主要介紹了Python表格數(shù)據(jù)處理庫(kù)之tablib庫(kù)詳解,Tablib是一個(gè)用于處理電子表格數(shù)據(jù)的Python庫(kù),它可以輕松地進(jìn)行數(shù)據(jù)的導(dǎo)入和導(dǎo)出,以及數(shù)據(jù)格式的轉(zhuǎn)換,需要的朋友可以參考下2023-08-08
Python操控mysql批量插入數(shù)據(jù)的實(shí)現(xiàn)方法
這篇文章主要介紹了Python操控mysql批量插入數(shù)據(jù)的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
python opencv3實(shí)現(xiàn)人臉識(shí)別(windows)
這篇文章主要為大家詳細(xì)介紹了python opencv3實(shí)現(xiàn)人臉識(shí)別程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
pytorch/transformers?最后一層不加激活函數(shù)的原因分析
這里給大家解釋一下為什么bert模型最后都不加激活函數(shù),是因?yàn)閾p失函數(shù)選擇的原因,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-01-01
vue學(xué)習(xí)筆記之動(dòng)態(tài)組件和v-once指令簡(jiǎn)單示例
這篇文章主要介紹了vue學(xué)習(xí)筆記之動(dòng)態(tài)組件和v-once指令,結(jié)合簡(jiǎn)單實(shí)例形式詳細(xì)分析了vue.js動(dòng)態(tài)組建點(diǎn)擊切換相關(guān)操作技巧,需要的朋友可以參考下2020-02-02
Ubuntu20.04環(huán)境安裝tensorflow2的方法步驟
這篇文章主要介紹了Ubuntu20.04環(huán)境安裝tensorflow2的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
在?Python?中創(chuàng)建DataFrame的方法
這篇文章主要介紹了教你如何在?Python?中創(chuàng)建DataFrame,我們將學(xué)習(xí)以多種方式創(chuàng)建DataFrame,DataFrame是數(shù)據(jù)的二維集合,是一種數(shù)據(jù)結(jié)構(gòu),其中數(shù)據(jù)以表格形式存儲(chǔ),更多相關(guān)資料需要的小伙伴可以參考一下2022-03-03

