Das Chatgpt.net ist eine C# -Bibliothek für ChatGPT, die offizielle OpenAI-API verwendet, mit der Entwickler auf ChatGPT zugreifen können, ein Chat-basierte Großsprachmodell. Mit dieser API können Entwickler Anfragen an ChatGPT senden und Antworten in Echtzeit erhalten, sodass es einfach ist, ChatGPT in ihre eigenen Anwendungen zu integrieren.
using ChatGPT . Net ;
// ChatGPT Official API
var bot = new ChatGpt ( " <API_KEY> " ) ;
var response = await bot . Ask ( " What is the weather like today? " ) ;
Console . WriteLine ( response ) ;
Aus Chatgpt.net führen Sie den folgenden Befehl in der Paket -Manager -Konsole aus:
Install-Package ChatGPT.Net
Alternativ können Sie es über die .NET-Core-Befehlszeilenschnittstelle installieren:
dotnet add package ChatGPT.Net
Hier ist ein Beispielcode, der zeigt, wie Sie Chatgpt.net verwenden:
using ChatGPT . Net ;
// ChatGPT Official API
var bot = new ChatGpt ( " <API_KEY> " ) ;
// get response
var response = await bot . Ask ( " What is the weather like today? " ) ;
Console . WriteLine ( response ) ;
// stream response
await bot . AskStream ( response => {
Console . WriteLine ( response ) ;
} , " What is the weather like today? " ) ;
// get response for a specific conversation
var response = await bot . Ask ( " What is the weather like today? " , " conversation name " ) ;
Console . WriteLine ( response ) ;
// stream response for a specific conversation
await bot . AskStream ( response => {
Console . WriteLine ( response ) ;
} , " What is the weather like today? " , " conversation name " ) ;
// Set a system message
bot . SetConversationSystemMessage ( " conversation name " , " You are a helpful assistant that provides clear and concise answers to questions. " ) ;
Einige Modelle können sowohl Text als auch Bilder verstehen. Um diese Funktion zu verwenden, müssen Sie eine Liste von Inhaltselementen übergeben, die sowohl Text als auch Bilder enthalten.
// To stream responses with both image and text input, create a list of content items
var contentItems = new List < ChatGptMessageContentItem > ( ) ;
// Each content item can be either "Text" type or "Image" type. Let's add text to inquire about the image
contentItems . Add ( new ChatGptMessageContentItem ( )
{
Type = ChatGptMessageContentType . TEXT ,
Text = " what is this image about? "
} ) ;
// Now, create another content item of "Image" type
var contentItemWithImage = new ChatGptMessageContentItem ( )
{
Type = ChatGptMessageContentType . IMAGE
} ;
// Set image by path
contentItemWithImage . SetImageFromFile ( " <path-to-file> " ) ;
// Or set image by Url
contentItemWithImage . SetImageFromUrl ( " https://path-to-image.com/image.png " ) ;
// Or set base64 image url
contentItemWithImage . SetImageFromUrl ( " data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA..... " ) ;
contentItems . Add ( contentItemWithImage ) ;
// Only specific models understand image input. Therefore, if you are using 'gpt-3.5-turbo' or similar model, switch or override the model before calling 'AskStream'. More details about `ChatGptOptions` (config) are covered in the next section.
config . Model = ChatGptModels . GPT_4_Vision_Preview ;
var response = await bot . AskStream ( response => {
Console . WriteLine ( response ) ;
} , contentItems , " conversation name " ) ;
Hier finden Sie einen Beispielcode, der zeigt, wie Sie mit Chatgpt.net (chat.openai.com) in Ihre Anwendungen integriert werden:
using ChatGPT . Net ;
// ChatGPT Official API
var bot = new ChatGptUnofficial ( " <SESSION_TOKEN> " ) ;
// get response
var response = await bot . Ask ( " What is the weather like today? " ) ;
Console . WriteLine ( response ) ;
// stream response
await bot . AskStream ( response => {
Console . WriteLine ( response ) ;
} , " What is the weather like today? " ) ;
// get response for a specific conversation
var response = await bot . Ask ( " What is the weather like today? " , " conversation name " ) ;
Console . WriteLine ( response ) ;
// stream response for a specific conversation
await bot . AskStream ( response => {
Console . WriteLine ( response ) ;
} , " What is the weather like today? " , " conversation name " ) ;
ChatGptOptions
{
string BaseUrl ; // Default: https://api.openai.com
string Model ; // Default: gpt-3.5-turbo
double Temperature ; // Default: 0.9;
double TopP ; // Default: 1.0;
long MaxTokens ; // Default: 64;
string [ ] ? Stop ; // Default: null;
double PresencePenalty ; // Default: 0.0;
double FrequencyPenaltyl ; // Default: 0.0;
}
ChatGptUnofficialOptions
{
string BaseUrl ; // Default: https://api.pawan.krd
string Model ; // Default: text-davinci-002-render-sha
}
Dies ist eine einfache Konsolen -App, die Chatgpt.net verwendet, um mit ChatGPT zu interagieren.
using ChatGPT . Net ;
// ChatGPT Official API
var bot = new ChatGpt ( " <API_KEY> " ) ;
var prompt = string . Empty ;
while ( true )
{
Console . Write ( " You: " ) ;
prompt = Console . ReadLine ( ) ;
if ( prompt is null ) break ;
if ( string . IsNullOrWhiteSpace ( prompt ) ) break ;
if ( prompt == " exit " ) break ;
Console . Write ( " ChatGPT: " ) ;
await bot . AskStream ( Console . Write , prompt , " default " ) ;
Console . WriteLine ( ) ;
}
Sie können ein anderes Modell verwenden, indem Sie den Modellnamen an den Konstruktor weitergeben.
var bot = new ChatGpt ( " <API_KEY> " , new ChatGptOptions
{
Model = " text-davinci-002-render-paid "
} ) ;
Sie können die offizielle CHATGPT -API verwenden, indem Sie die Basis -URL auf einen kostenlosen Reverse -Proxy -Server wie ChatGPT Free Reverse Proxy einstellen
var bot = new ChatGpt ( " <API_KEY> " , new ChatGptOptions
{
BaseUrl = " https://api.pawan.krd "
} ) ;
Dieses Projekt ist unter der MIT -Lizenz lizenziert - finden Sie in der Lizenzdatei Einzelheiten