UIUIAPI聚合平台API通用代码教程

号优优网uiuihao
预计阅读时长 44 分钟
位置: 首页 AI工具 正文

null

API 站点使用教程

API快速使用工具推荐 🔥

UIUIAPI在线AI工具

1.1 API 接口地址填写

请勿将 API Key 泄露给他人,一旦泄露,请立即删除并创建新的 API Key
修改原则:修改应用 BASE_URL 为其中一个中转接口调用地址接口即可,例如:

修改原则
https://api.openai.com

https://sg.uiuiapi.com

(如果原来接口地址需要加 /v1 的话我们的接口地址也需要在后面加 /v1)

出现回复缓慢的情况,请检查 API 调用日志,若日志正常,则自行调整网络。

Base Url
不同客户端适配的接口地址格式不同,通常为以下三种:

  1. https://sg.uiuiapi.com
  2. https://sg.uiuiapi.com/v1
  3. https://sg.uiuiapi.com/v1/chat/completions

1.2 Python 接入示例

所有对话模型均使用 OpenAI 格式,替换AI模型即可

Python 流式

from openai import OpenAI

api_key = "sk-HTdmSI6B2cNt************************************"
api_base = "https://sg.uiuiapi.com/v1"
client = OpenAI(api_key=api_key, base_url=api_base)

completion = client.chat.completions.create(
  model="claude-3-opus-20240229",
  stream: True,
  messages=[
    {"role": "system", "content": "You are a helpful assistant."},
    {"role": "user", "content": "Hello!"}
  ]
)

for chunk in completion:
  print(chunk.choices[0].delta)

Python 非流

from openai import OpenAI

api_key = "sk-HTdmSI6B2cNt************************************"
api_base = "https://sg.uiuiapi.com/v1"
client = OpenAI(api_key=api_key, base_url=api_base)

completion = client.chat.completions.create(
  model="claude-3-opus-20240229",
  stream: False,
  messages=[
    {"role": "system", "content": "You are a helpful assistant."},
    {"role": "user", "content": "Hello!"}
  ]
)

print(completion.choices[0].message)

Python Whisper 语音转文字

from openai import OpenAI
from pathlib import Path

# 设置你的基础URL和API密钥
base_url = "https://sg.uiuiapi.com/v1"
key = "sk-HTdmSI6B2cNt************************************"

# 初始化OpenAI客户端
client = OpenAI(api_key=key, base_url=base_url)

# 音频文件的路径
audio_file_path = "C:/speech.mp3"

# 打开音频文件
with open(audio_file_path, "rb") as audio_file:
    # 创建转录
    transcription = client.audio.transcriptions.create(
        model="whisper-1", 
        file=audio_file
    )

# 打印转录文本
print(transcription.text)

Python TTS 文字转语音

from openai import OpenAI
from pathlib import Path

def test_text_speech(model="tts-1"):
    print(f"Testing {model} - text to speech")
    speech_file_path = Path(__file__).parent / "speech1.mp3"
    response = client.audio.speech.create(
        model=model,
        voice="alloy", # 可选 alloy, echo, fable, onyx, nova, shimmer
        input="示例文本",
    )
    response.stream_to_file(speech_file_path)

base_url = "https://sg.uiuiapi.com/v1"
key = "sk-HTdmSI6B2cNt************************************"

client = OpenAI(base_url=base_url, api_key=key)

test_text_speech()

go 实例、java 实例

java 实例

import okhttp3.*;

import java.io.IOException;

public class OpenAIChat {

    public static void main(String[] args) {
        String url = "https://sg.uiuiapi.com/v1/chat/completions";
        
        OkHttpClient client = new OkHttpClient();

        MediaType mediaType = MediaType.parse("application/json");

        String json = "{\n" +
                "  \"max_tokens\": 1200,\n" +
                "  \"model\": \"gpt-3.5-turbo\",\n" +
                "  \"temperature\": 0.8,\n" +
                "  \"top_p\": 1,\n" +
                "  \"presence_penalty\": 1,\n" +
                "  \"messages\": [\n" +
                "    {\n" +
                "      \"role\": \"system\",\n" +
                "      \"content\": \"You are ChatGPT, a large language model trained by OpenAI. Answer as concisely as possible.\"\n" +
                "    },\n" +
                "    {\n" +
                "      \"role\": \"user\",\n" +
                "      \"content\": \"你是chatGPT多少?\"\n" +
                "    }\n" +
                "  ]\n" +
                "}";

        RequestBody body = RequestBody.create(mediaType, json);
        Request request = new Request.Builder()
                .url(url)
                .post(body)
                .addHeader("Content-Type", "application/json")
                .addHeader("Authorization", "Bearer sk-HTdmSI6B2cNt************************************)
                .build();

        try (Response response = client.newCall(request).execute()) {
            if (response.isSuccessful()) {
                String result = response.body().string();
                System.out.println(result);
            } else {
                System.err.println("Request failed: " + response);
            }
        } catch (IOException e) {
            System.err.println("Error during API call: " + e.getMessage());
        }
    }
}

go 实例

package main

import (
    "bytes"
    "encoding/json"
    "fmt"
    "io/ioutil"
    "net/http"
    "os"
)

func main() {
    url := "https://sg.uiuiapi.com/v1/chat/completions"
    apiKey := "sk-HTdmSI6B2cNt************************************"

    if apiKey == "" {
        fmt.Println("API Key is not set")
        return
    }

    payload := map[string]interface{}{
        "max_tokens":       1200,
        "model":            "gpt-3.5-turbo",
        "temperature":      0.8,
        "top_p":            1,
        "presence_penalty": 1,
        "messages": []map[string]string{
            {
                "role":    "system",
                "content": "You are ChatGPT, a large language model trained by OpenAI. Answer as concisely as possible.",
            },
            {
                "role":    "user",
                "content": "你是chatGPT多少?",
            },
        },
    }

    jsonPayload, err := json.Marshal(payload)
    if err != nil {
        fmt.Println("Error encoding JSON payload:", err)
        return
    }

    req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonPayload))
    if err != nil {
        fmt.Println("Error creating HTTP request:", err)
        return
    }

    req.Header.Set("Authorization", "Bearer "+apiKey)
    req.Header.Set("Content-Type", "application/json")

    client := &http.Client{}
    resp, err := client.Do(req)
    if err != nil {
        fmt.Println("Error making API request:", err)
        return
    }
    defer resp.Body.Close()

    if resp.StatusCode != http.StatusOK {
        fmt.Printf("Request failed with status: %d\n", resp.StatusCode)
        return
    }

    body, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        fmt.Println("Error reading response body:", err)
        return
    }

    fmt.Println("Response:", string(body))
}

1.3 Curl 接入示例

Curl 流式

curl https://sg.uiuiapi.com/v1/chat/completions \
       -H "Content-Type: application/json" \
       -H "Authorization: Bearer sk-HTdmSI6B2cNt************************************" \
       -d '{
            "model": "claude-3-opus-20240229",
            "stream": true,
            "messages": [{ "role": "user", "content": "say 1" }]
            }'

Curl 非流

curl https://sg.uiuiapi.com/v1/chat/completions \
       -H "Content-Type: application/json" \
       -H "Authorization: Bearer sk-HTdmSI6B2cNt************************************" \
       -d '{
            "model": "claude-3-opus-20240229",
            "stream": false,
            "messages": [{ "role": "user", "content": "say 1" }]
            }'

1.4 Node.js 接入示例

Node.js 流式

import OpenAI from "openai";

const openai = new OpenAI({
  apiKey: 'sk-HTdmSI6B2cNt************************************',
  baseURL: "https://sg.uiuiapi.com/v1"
});

async function main() {
  try {
    const completionStream = await openai.chat.completions.create({
      stream: true,
      messages: [{ role: "system", content: "You are a helpful assistant." }],
      model: "claude-3-opus-20240229",
    });

    completionStream.on('data', (chunk) => {
      const data = chunk.toString();
      try {
        const parsed = JSON.parse(data);
        console.log(parsed.choices[0]);
      } catch (error) {
        console.error("Error parsing JSON:", error);
      }
    });

    completionStream.on('end', () => {
      console.log("Stream ended.");
    });

    completionStream.on('error', (error) => {
      console.error("Stream error:", error);
    });

  } catch (error) {
    console.error("Error in API call:", error);
  }
}

main();

Node.js 非流

import OpenAI from "openai";

const openai = new OpenAI({
  apiKey: 'sk-HTdmSI6B2cNt************************************',
  baseURL: "https://sg.uiuiapi.com/v1"
});

async function main() {
  try {
    const completion = await openai.chat.completions.create({
      stream: false,
      messages: [{ role: "system", content: "You are a helpful assistant." }],
      model: "claude-3-opus-20240229",
    });

    console.log(completion.choices[0].message.content);
  } catch (error) {
    console.error("Error in API call:", error);
  }
}

main();

1.5 Python使用Claude、gpt-4o识别图片

识别链接格式图片

from openai import OpenAI

client = OpenAI(
    base_url="https://sg.uiuiapi.com/v1",
    api_key=key
)

response = client.chat.completions.create(
  model="gpt-4o",
  messages=[
    {
      "role": "user",
      "content": [
        {"type": "text", "text": "What’s in this image?"},
        {
          "type": "image_url",
          "image_url": {
            "url": "https://upload.wikimedia.org/wikipedia/commons/thumb/d/dd/Gfp-wisconsin-madison-the-nature-boardwalk.jpg/2560px-Gfp-wisconsin-madison-the-nature-boardwalk.jpg",
          },
        },
      ],
    }
  ],
  max_tokens=300,
)

print(response.choices[0])

识别Base64格式图片

import base64
import time
from openai import OpenAI
import openai

key = 'sk-xxxx' 

client = OpenAI(
    base_url="https://sg.uiuiapi.com/v1",
    api_key=key
)


def encode_image(image_path):
    with open(image_path, "rb") as image_file:
        return base64.b64encode(image_file.read()).decode('utf-8')


image_path = "图片.jpg"

base64_image = encode_image(image_path)

while True:
    response = client.chat.completions.create(
        model="claude-3-5-sonnet-20240620",
        messages=[
            {
                "role": "user",
                "content": [
                    {"type": "text", "text": "这张图片里有什么?请详细描述。"},
                    {
                        "type": "image_url",
                        "image_url": {
                            "url": f"data:image/jpeg;base64,{base64_image}"
                        }
                    }
                ]
            }
        ],
        temperature=1
    )
    print(response)
    print(response.choices[0].message.content)
    time.sleep(1)

dall-e-3、Midjourney接入画图模型示例

dall-e-3 画图模型

其他语言 可通过curl实例 用ChatGPT转下

curl https://sg.uiuiapi.com/v1/images/generations \
  -H "Authorization: Bearer sk-xxxx" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "dall-e-3",
    "prompt": "a white siamese cat",
    "n": 1,
    "size": "1024x1024"
  }'

Midjourney 画图接入向导 程序实例

本章以提交 Imagine 任务为例子介绍如何使用OpenAI-uiuiapi的api key接入 Midjourney;
点击这里查看更多API接口

模式接入点

curl 实例

第一步:提交Imagine任务

接口说明 获取到任何ID result:1320098173412546

curl --request POST \
  --url https://sg.uiuiapi.com/fast/mj/submit/imagine \
  --header 'Authorization: Bearer sk-xxxxxx替换为你的key' \
  -H "Content-Type: application/json" \
  --data '{
  "base64Array": [],
  "instanceId": "",
  "modes": [],
  "notifyHook": "https://ww.baidu.com/notifyHook/back",
  "prompt": "black cat",
  "remix": true,
  "state": ""
}'
第二步:根据任务ID获取任务结果

由第一步得到任务ID为 :1320098173412546 得到返回结果。
返回结果说明,请参考返回结果说明

curl --request GET \
  --url https://sg.uiuiapi.com/fast/mj/task/1320098173412546/fetch \
  --header 'Authorization: Bearer sk-xxxxxx替换为你的key' \
  -H "Content-Type: application/json"
声明:本文内容及配图来自互利网收集整理撰写或者入驻合作网站授权转载。文章及其配图仅供学习之用,如有内容图片侵权或者其他问题,请联系本站侵删。
-- 展开阅读全文 --
头像
热讯:Google Gemini 模型更新后,OpenAI o1 API 迅速跟进可用性更新
« 上一篇 2024-09-25
Claude又发新货:3.5 Sonnet和3.5 Haiku重磅登场 附Claude 3.5 API Key价格
下一篇 » 2024-10-23

相关文章

取消
微信二维码
微信二维码
支付宝二维码

发表评论

暂无评论,1520人围观

作者信息

似水流年

今日已经过去小时
这周已经过去
本月已经过去
今年已经过去个月

热门文章

系统获取,无需修改

标签列表

目录[+]