Youtube API 搜索自动完成

问题描述 投票:0回答:7

我正在使用Youtube API,我希望有一个搜索自动完成功能,就像在YouTube上一样,当您在搜索输入框中键入内容时,它会给您搜索建议。 我已阅读文档,但仍然缺少,可以使用 API 实现这一点吗?

search autocomplete youtube youtube-api
7个回答
62
投票

好的,我找到了这个网址:

http://suggestqueries.google.com/complete/search?client=firefox&ds=yt&q=Query

它不是 Youtube API 的一部分,但仍然有效,返回 JSON 响应。



4
投票

以上所有 api 都,并提供 google 搜索建议,而不是 youtube 搜索建议

使用这个:

https://clients1.google.com/complete/search?client=youtube&gs_ri=youtube&ds=yt&q=faded

使用以下 JS 代码提取建议:

//  data is response of above api
   const data = 'window.google.ac.h(["faded",[["faded",0,[433]],["faded alan walker lyrics",0,[433]],["faded remix",0,[433]],["faded 8d",0,[433]],["faded piano",0,[433]],["faded wheel free fire",0],["faded karaoke",0,[433]],["faded ringtone",0,[433]],["faded instrumental",0,[433]],["faded live",0,[433]],["faded piano tutorial",0,[433]],["faded whatsapp status",0,[433]],["faded dhol cover",0,[433]],["faded dance",0,[433]]],{"k":1,"q":"_sPyvXmmbfcsVtfP4sgjOdKQAvg"}])';

    const searchSuggestions = [];
    data.split('[').forEach((ele, index) => {
      if (!ele.split('"')[1] || index === 1) return;
        return searchSuggestions.push(ele.split('"')[1]);
    });
    console.log(searchSuggestions);


0
投票

查看YouTube 自动完成关键字抓取器。不太确定提出问题的人想要 YouTube 自动完成解决方案的背景,但我想我会把它扔在那里。


0
投票

您也可以使用 JSON:

url: "https://suggestqueries.google.com/complete/search?client=youtube&ds=yt&q=" + i,
        dataType: "jsonp",

0
投票

官方:

https://suggestqueries-clients6.youtube.com/complete/search?client=youtube-reduced&hl=en&gs_ri=youtube-reduced&ds=yt&cp=3&gs_id=100&q=Nectar&xhr=t&xssi=t&gl=us

您也可以选择国家。

附注我在美国搜索了 Nectar


0
投票

你可以直接解析响应,先剪掉不需要的部分

const arr = JSON.parse(str.substring(str.indexOf("["), str.indexOf("])") + 1));

这是结果的形状

let suggestionsTuple: [string, number, number[]][] = [];

我们需要的只是过滤掉

string
s

if (Array.isArray(arr) && Array.isArray(arr.at(1))) {
    suggestionsTuple = arr.at(1);
}

const suggestions = suggestionsTuple.flatMap((suggestion) => suggestion).filter((suggestion) => typeof suggestion === "string"); // ["Hello" ,"Hello there"]
© www.soinside.com 2019 - 2024. All rights reserved.