首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用youtube API获取频道的所有视频

使用youtube API获取频道的所有视频
EN

Stack Overflow用户
提问于 2015-05-06 15:33:25
回答 4查看 33.8K关注 0票数 13

我想得到所有的视频单一频道,我有它的Id。我只得到频道信息的问题。这是我使用的链接:

KkDG4Dz5A?v=2&alt=json&q=goal&orderby=published&max-results=10

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2015-05-06 19:03:47

该链接用于现已退役的V2 API,因此它不会返回任何数据。相反,您需要使用API的V3。您需要做的第一件事是注册一个API密钥--您可以通过在console.developers.google.com上创建一个项目,将YouTube数据API设置为"on“,并创建一个公共访问密钥来做到这一点。

由于您已经有了用户频道ID,您可以直接从它获取视频;但是,请注意,如果您不知道频道ID,您可以这样获得它:

代码语言:javascript
复制
https://www.googleapis.com/youtube/v3/channels?part=snippet&forUsername={username}&key={YOUR_API_KEY}

使用通道ID,您可以从带有搜索端点的频道获取所有视频,如下所示:

代码语言:javascript
复制
https://www.googleapis.com/youtube/v3/search?order=date&part=snippet&channelId={channel id here}&maxResults=25&key={YOUR_API_KEY}

在本例中,按日期排序与旧的V2参数相同,用于按“已发布”进行排序。

在搜索频道时,还可以使用许多其他参数来检索视频;有关更多细节,请参见https://developers.google.com/youtube/v3/docs/search/list

票数 58
EN

Stack Overflow用户

发布于 2015-11-17 21:10:04

我想我应该使用JavaScript来分享我的最终结果。它使用Google键和YouTube UserName获取频道ID,然后将视频和显示在列表中显示到给定的div标记中。

代码语言:javascript
复制
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>YouTube Channel Listing</title>
    <script type="text/javascript">
        function getJSONData(yourUrl) {
            var Httpreq = new XMLHttpRequest();
            try {
                Httpreq.open("GET", yourUrl, false);
                Httpreq.send(null);
            } catch (ex) {
                alert(ex.message);
            }
            return Httpreq.responseText;
        }
        function showVideoList(username, writediv, maxnumbervideos, apikey) {
            try {
                document.getElementById(writediv).innerHTML = "";
                var keyinfo = JSON.parse(getJSONData("https://www.googleapis.com/youtube/v3/channels?part=snippet&forUsername=" + username + "&key=" + apikey));
                var userid = keyinfo.items[0].id;
                var channeltitle = keyinfo.items[0].snippet.title;
                var channeldescription = keyinfo.items[0].snippet.description;
                var channelthumbnail = keyinfo.items[0].snippet.thumbnails.default.url; // default, medium or high
                //channel header
                document.getElementById(writediv).innerHTML += "<div style='width:100%;min-height:90px;'>"
                    + "<a href='https://www.youtube.com/user/" + username + "' target='_blank'>"
                    + "<img src='" + channelthumbnail + "' style='border:none;float:left;margin-right:10px;' alt='" + channeltitle + "' title='" + channeltitle + "' /></a>"
                    + "<div style='width:100%;text-align:center;'><h1><a href='https://www.youtube.com/user/" + username + "' target='_blank'>" + channeltitle + "</a></h1>" + channeldescription + "</div>"
                    + "</div>";
                var videoinfo = JSON.parse(getJSONData("https://www.googleapis.com/youtube/v3/search?order=date&part=snippet&channelId=" + userid + "&maxResults=" + maxnumbervideos + "&key=" + apikey));
                var videos = videoinfo.items;
                var videocount = videoinfo.pageInfo.totalResults;
                // video listing
                for (var i = 0; i < videos.length; i++) {
                    var videoid = videos[i].id.videoId;
                    var videotitle = videos[i].snippet.title;
                    var videodescription = videos[i].snippet.description;
                    var videodate = videos[i].snippet.publishedAt; // date time published
                    var videothumbnail = videos[i].snippet.thumbnails.default.url; // default, medium or high
                    document.getElementById(writediv).innerHTML += "<hr /><div style='width:100%;min-height:90px;'>"
                        + "<a href='https://www.youtube.com/watch?v=" + videoid + "' target='_blank'>"
                        + "<img src='" + videothumbnail + "' style='border:none;float:left;margin-right:10px;' alt='" + videotitle + "' title='" + videotitle + "' /></a>"
                        + "<h3><a href='https://www.youtube.com/watch?v=" + videoid + "' target='_blank'>" + videotitle + "</a></h3>" + videodescription + ""
                        + "</div>";
                }
            } catch (ex) {
                alert(ex.message);
            }
        }
    </script>
</head>
<body>
    <div id="videos"></div>
    <script type="text/javascript">
        showVideoList("USER_NAME", "videos", 25, "YOUR_API_KEY");
    </script>
</body>
</html>

添加-我还编写了一个函数来处理,如果您使用的是一个通道ID,而不是一个基于UserName的帐户。

这是代码:

代码语言:javascript
复制
        function showVideoListChannel(channelid, writediv, maxnumbervideos, apikey) {
        try {
            document.getElementById(writediv).innerHTML = "";
            var vid = getJSONData("https://www.googleapis.com/youtube/v3/search?order=date&part=snippet&channelId=" + channelid + "&maxResults=" + (maxnumbervideos + 1) + "&key=" + apikey);
            var videoinfo = JSON.parse(vid);
            var videos = videoinfo.items;
            var videocount = videoinfo.pageInfo.totalResults;
            var content = "<div style='height:600px;overflow-y:auto;'>";
            for (var i = 0; i < videos.length - 1; i++) {
                var videoid = videos[i].id.videoId;
                var videotitle = videos[i].snippet.title;
                var videodescription = videos[i].snippet.description;
                var videodate = videos[i].snippet.publishedAt; // date time published
                var newdate = new Date(Date.parse((videodate + " (ISO 8601)").replace(/ *\(.*\)/, "")));
                var min = newdate.getMinutes();
                if (min < 10) {
                    min = "0" + min;
                }
                if (newdate.getHours() > 12) {
                    newdate = newdate.getMonth() + 1 + "/" + newdate.getDate() + "/" + newdate.getFullYear() + " " + (newdate.getHours() - 12) + ":" + min + " PM";
                } else if (newdate.getHours() == 12) {
                    newdate = newdate.getMonth() + 1 + "/" + newdate.getDate() + "/" + newdate.getFullYear() + " " + newdate.getHours() + ":" + min + " PM";
                } else {
                    newdate = newdate.getMonth() + 1 + "/" + newdate.getDate() + "/" + newdate.getFullYear() + " " + newdate.getHours() + ":" + min + " AM";
                }
                var videothumbnail = videos[i].snippet.thumbnails.default.url; // default, medium or high
                content += "<hr /><div style='width:100%;min-height:90px;'>"
                    + "<a href='https://www.youtube.com/watch?v=" + videoid + "' target='_blank'>"
                    + "<img src='" + videothumbnail + "' style='border:none;float:left;margin-right:10px;' alt='" + videotitle + "' title='" + videotitle + "' /></a>"
                    + "<h3><a href='https://www.youtube.com/watch?v=" + videoid + "' target='_blank'>" + videotitle + "</a></h3>" + videodescription + "<br />"
                    + "<span style='color:#738AAD;font-size:Small;'>" + newdate + "</span>"
                    + "</div>";
            }
            content += "</div>";
            document.getElementById(writediv).innerHTML = content;
        } catch (ex) {
            alert(ex.message);
        }
    }
票数 5
EN

Stack Overflow用户

发布于 2020-09-15 12:04:04

使用通道API键获取频道视频是非常简单的方法:

步骤1:您必须有一个YouTube帐户。

步骤2:创建YouTube通道API键

步骤3:创建项目console.developers.google.com,

代码语言:javascript
复制
<?php
$API_key    = 'Your API key'; //my API key dei;
$channelID  = 'Your Channel ID'; //my channel ID
$maxResults = 5;
$video_list = 
json_decode(file_get_contents('https://www.googleapis.com/youtube/v3/search? 
order=date&part=snippet&channelId='.$channelID.
'&maxResults='.$maxResults.'&key='.$API_key.''));
?>



Example : https://www.googleapis.com/youtube/v3/channelspart=snippet&forUsername= 
{username}&key={YOUR_API_KEY}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30081301

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档