Rumah  >  Artikel  >  Peranti teknologi  >  Pelaksanaan skrip pelayar terjemahan penanda perkataan berdasarkan API ChatGPT

Pelaksanaan skrip pelayar terjemahan penanda perkataan berdasarkan API ChatGPT

王林
王林ke hadapan
2023-05-01 15:28:141191semak imbas

Kata Pengantar

Baru-baru ini terdapat skrip penyemak imbas berdasarkan API ChatGPT di GitHub, openai-translator Dalam tempoh yang singkat, bintang itu telah mencapai 12k Selain menyokong terjemahan, ia juga menyokong penggilap dan meringkaskan fungsi. Selain pemalam penyemak imbas, tauri juga digunakan untuk membungkus klien desktop Tanpa mengira tauri dan menggunakan bahagian karat, bahagian penyemak imbas agak mudah untuk dilaksanakan hari ini.

Antara muka disediakan oleh openAI

Sebagai contoh, kita boleh menyalin kod berikut dan memulakan permintaan dalam konsol penyemak imbas untuk melengkapkan terjemahan

//示例
const OPENAI_API_KEY = "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";

const prompt = `Translate this into Chinese:
hello world`;
const res = await fetch("https://api.openai.com/v1/completions", {
method: "POST",
headers: {
"Content-Type": "application/json",
authorization: `Bearer ${OPENAI_API_KEY}`,
},
body: JSON.stringify({
model: "text-davinci-003",
prompt,
max_tokens: 1000,
temperature: 0,
}),
});
const response = await res.json();

const result = response.choices[0].text;

OPONAI_API_KEY dalam keperluan kod di atas untuk diganti dengan milik anda sendiri.

Realisasikan terjemahan perkataan

Terjemahan perkataan ialah fungsi halaman web biasa Apabila pengguna memilih perkataan atau teks, tetingkap kecil akan muncul secara automatik untuk memaparkan terjemahan perkataan atau teks .

  1. Mula-mula, tambahkan elemen DIV kosong dan butang untuk mencetuskan terjemahan dalam halaman HTML
let keyword;
const translation = document.createElement("div"); 
translation.id ="translation"; 
const icon = document.createElement("img"); 
icon.style.width ="30px";
icon.style.height = "30px";
icon.src ="http://example.com/icon.png";
translation.appendChild(icon)
  1. Tambahkan pendengar acara tetikus ke halaman , apabila pengguna memilih sekeping teks, tetapkan kata kunci carian.
document.addEventListener("mouseup", (event) => {
const selection = window.getSelection().toString().trim();
if (selection) {
keyword=selection;
}
});
  1. Klik tetikus untuk melaksanakan logik terjemahan. Anda boleh menggunakan permintaan AJAX untuk mendapatkan hasil terjemahan dari latar belakang dan memaparkannya dalam elemen DIV.
function translate(){
if(keyword){
// 执行翻译逻辑
}
}
icon.addEventListener("mouseover", translate);
  1. Tambahkan gaya pada elemen DIV dalam lembaran gaya CSS supaya ia terapung dan dipaparkan pada halaman.
#translation {
position: fixed;
top: 10px;
right: 10px;
max-width: 300px;
padding: 5px;
background-color: #f7f7f7;
border: 1px solid #ccc;
box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.1);
z-index: 9999;
}

Langkah di atas dapat merealisasikan fungsi asas terjemahan perkataan. Mari kita lihat kesannya.

基于 ChatGPT API 的划词翻译浏览器脚本实现

react + antd pelaksanaan

Kod di atas hanya melaksanakan versi paling mudah, gaya Ia tidak cantik cukup, jadi kita boleh menggunakan webpack + react + antd untuk melaksanakan pemalam moden Di sini saya menggunakan templat tampermonkey-starter yang dibuat sebelum ini.

Gunakan komponen Popover antd untuk dipaparkan dan gunakan tindak balas untuk membina semula kod js, dan kita boleh mencapai kesan berikut.

基于 ChatGPT API 的划词翻译浏览器脚本实现

Terjemahan Perkataan

Klik butang terjemahan dan hasil terjemahan akan dipaparkan melalui antara muka permintaan di bawah. Walau bagaimanapun, hasil terjemahan tidak akan dipaparkan sehingga api kembali sepenuhnya, yang akan menjadikan penantian lebih perlahan Bolehkah kita menggunakan Strim Adakah antara muka OpenAI menyokong pemaparan aliran?

import { createParser } from "eventsource-parser";

const translate = async (text: string) => {
const resp = await fetch("https://api.openai.com/v1/completions", {
method: "POST",
headers: {
"Content-Type": "application/json",
authorization:
`Bearer ${OPENAI_API_KEY}`,
},
body: JSON.stringify({
model: "text-davinci-003",
prompt: `Translate this into Chinese:
${text}`,
max_tokens: 1000,
temperature: 0,
frequency_penalty: 0,
stream: true,
}),
});
if (resp.status !== 200) {
const res = await resp.json();
setLoading(false);
console.error(res);
return;
}
const parser = createParser((event) => {
if (event.type === "event") {
const data = event.data;
if (data === "[DONE]") {
setLoading(false);
}
try {
let json = JSON.parse(event.data);
setResult((prev) => {
return prev + json.choices[0].text;
});
} catch (error) {
console.log(error);
}
}
});
const data = resp.body;
if (!data) {
console.log("Error: No data received from API");
return;
}
const reader = resp.body.getReader();
try {
while (true) {
const { done, value } = await reader.read();
if (done) {
setLoading(false);
break;
}
const str = new TextDecoder().decode(value);
parser.feed(str);
}
} finally {
reader.releaseLock();
}
};

Dalam kod di atas, kami menggunakan API pengambilan untuk menghantar permintaan HTTP dan mendapatkan strim yang boleh dibaca dalam respons. Kita boleh menggunakan kaedah getReader untuk mendapatkan objek pembaca dan menggunakannya untuk memproses data strim, menggunakan pakej eventsource-parser untuk menghuraikan data daripada acara yang dihantar pelayan.

Dengan cara ini, kandungan respons akan dipaparkan satu persatu mengikut acara yang dihantar oleh Pelayan (acara yang dihantar oleh pelayan).

基于 ChatGPT API 的划词翻译浏览器脚本实现

Teks ke Ucapan

Terjemahan am Semua pemalam mempunyai fungsi main balik suara dan kami boleh menggunakan API Pertuturan Web. API ini menyediakan dua antara muka sintesis pertuturan: SpeechSynthesis dan SpeechSynthesisUtterance

function speak(text) {
if ('speechSynthesis' in window) {
const utterance = new SpeechSynthesisUtterance(text);
utterance.voice = speechSynthesis.getVoices()[0];
utterance.pitch = 1;
utterance.rate = 1;
speechSynthesis.speak(utterance);
}
}

Kemudian panggil terus fungsi ini dan hantarkan teks yang perlu dibaca dengan kuat untuk merealisasikan main balik pertuturan

speak('Hello, world!');

Ringkasan

Artikel ini memperkenalkan cara untuk melaksanakan fungsi asas terjemahan perkataan, termasuk menggunakan antara muka yang disediakan oleh OpenAI untuk terjemahan, menambah butang yang mencetuskan terjemahan dan acara mendengar acara tetikus dalam halaman HTML, menggunakan permintaan AJAX untuk mendapatkan hasil terjemahan daripada antara muka, dan Ia dipaparkan dalam elemen DIV. Ia juga memperkenalkan cara menggunakan webpack + react + antd untuk melaksanakan pemalam moden dan menggunakan Web Speech API untuk melaksanakan fungsi main balik suara.

Atas ialah kandungan terperinci Pelaksanaan skrip pelayar terjemahan penanda perkataan berdasarkan API ChatGPT. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:51cto.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam