Python調(diào)用ChatGPT的API實(shí)現(xiàn)文章生成
實(shí)操目標(biāo)
最近ChatGPT大火,在3.5版本后開放了接口API,所以很多人開始進(jìn)行實(shí)操,這里我就用python來為大家實(shí)現(xiàn)一下,如何調(diào)用API并提問返回文章的說明
實(shí)操內(nèi)容
獲取API
書寫python調(diào)用框架
封裝到pyqt中,實(shí)現(xiàn)UI化
封裝為exe
具體操作
話不多說,直接上代碼
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): # 從文本框中獲取問題 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('小杰巨無霸gpt自動(dòng)生成器') self.resize(500, 400) # 創(chuàng)建一個(gè)垂直布局,并將所有控件添加到布局中 layout = QVBoxLayout() # 創(chuàng)建一個(gè)標(biāo)簽,并添加到布局中 label = QLabel('請(qǐng)?jiā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('開始生成') 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): # 從文本框中獲取問題 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)單,有興趣的伙伴可以深化美化一番。
直接輸入問題,就可以生成答案!
到此這篇關(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-08Python操控mysql批量插入數(shù)據(jù)的實(shí)現(xiàn)方法
這篇文章主要介紹了Python操控mysql批量插入數(shù)據(jù)的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10python opencv3實(shí)現(xiàn)人臉識(shí)別(windows)
這篇文章主要為大家詳細(xì)介紹了python opencv3實(shí)現(xiàn)人臉識(shí)別程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05pytorch/transformers?最后一層不加激活函數(shù)的原因分析
這里給大家解釋一下為什么bert模型最后都不加激活函數(shù),是因?yàn)閾p失函數(shù)選擇的原因,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-01-01vue學(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-02Ubuntu20.04環(huán)境安裝tensorflow2的方法步驟
這篇文章主要介紹了Ubuntu20.04環(huán)境安裝tensorflow2的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(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