Youtube API v3 的内容详细信息、持续时间和统计信息存在问题
Problems with contentDetails, duration and statistics from the Youtube API v3
我正在尝试为每个视频检索 duration
和 viewCount
的值,它们都在 videos:list api 下。我创建了一个单独的函数,它将 return 每个视频持续时间和统计信息。唯一有效的是检索到的视频播放列表和 getPlaylist(...)
函数中的 videoId
。我登录到控制台,这就是我得到的:
console.log("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
id: xxx duration: undefined viewCount: undefined
我从来没有工作的时间,但我注意到 api 和 part: statistics
将从注释掉的频道中检索观看次数总和的值。但这不是我要找的。我希望它与每个视频一起使用:
GET https://www.googleapis.com/youtube/v3/videos
但出于某种原因,我无法让它工作。我有 videoId
属性 和作为参数,所以 playlistId 可以读取它并检索视频持续时间和观看次数的所述值,但它仍然未定义,即使 videoId
已经定义。哦,警报对话框也没有出现。
我在这里错过了什么?
脚本:
var channelName = 'ExampleChannel';
var vidWidth = 500;
var vidHeight = 400;
var vidResults = 15; /* # of videos to show at once - max 50 */
var vidDuration = "";
var viewCount = 0;
var videoId = "";
$(document).ready(function() {
$.get( // get channel name and load data
"https://www.googleapis.com/youtube/v3/channels",
{
part: 'contentDetails',
forUsername: channelName,
key: 'XXXXXXXXXX'
},
function(data)
{
$.each(data.items,
function(i, item) {
console.log(item); // log all items to console
var playlistId = item.contentDetails.relatedPlaylists.uploads;
//var viewCount = console.log(item.statistics.viewCount);
getPlaylists(playlistId);
})
}
);
// function that gets the playlists
function getPlaylists(playlistId)
{
$.get(
"https://www.googleapis.com/youtube/v3/playlistItems",
{
part: 'snippet',
maxResults: vidResults,
playlistId: playlistId,
key: 'XXXXXXXXXX'
},
// print the results
function(data)
{
var output;
$.each(data.items,
function(i, item) {
console.log(item);
var vidTitle = item.snippet.title; // video title
var vidDesc = item.snippet.description; // video description
var videoId = item.snippet.resourceId.videoId; // video id
// check if description is empty
if(vidDesc == null || vidDesc == "")
{
vidDesc = "No description was written."; // FIX: test msg to see where it still shows up
$('#desc').remove(); // remove video description
}
else vidDesc = item.snippet.description;
vidDuration = getVideoDuration(videoId);
viewCount = getViewCount(videoId);
console.log("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
output = '<li><iframe height="' + vidHeight + '" width="' + vidWidth + '" src=\"//www.youtube.com/embed/' + videoId + '\"></iframe></li><div id="title">' + vidTitle + '</div><div id="desc">' + vidDesc + '</div><div id="duration">Length: ' + vidDuration + '</div><div id="stats">View Count: ' + viewCount + '</div>';
// Append results to list tag
$('#results').append(output);
})
}
);
}
// return video duration
function getVideoDuration(videoId)
{
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails',
id: videoId,
key: 'XXXXXXXXXX',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
alert(item.contentDetails.duration); // video duration
//alert(videoId);
})
}
);
}
// return video view count
function getViewCount(videoId)
{
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails, statistics',
id: videoId,
key: 'XXXXXXXXXX',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
alert(item.statistics.viewCount); // view count
//alert(videoId);
})
}
);
}
});
截图:(更新)
因为当您调用这些函数时,您不会等待函数完成。
您需要在 Javascript.
中使用 Promise
我稍微更改了您的代码(使用我的 api 密钥进行了测试)
var channelName = 'example';
var vidWidth = 500;
var vidHeight = 400;
var vidResults = 15; /* # of videos to show at once - max 50 */
var vidDuration = "";
var viewCount = 0;
var videoId = "";
$(document).ready(function() {
$.get( // get channel name and load data
"https://www.googleapis.com/youtube/v3/channels",
{
part: 'contentDetails',
forUsername: channelName,
key: 'xxx'
},
function(data)
{
$.each(data.items,
function(i, item) {
//console.log(item); // log all items to console
var playlistId = item.contentDetails.relatedPlaylists.uploads;
//var viewCount = console.log(item.statistics.viewCount);
getPlaylists(playlistId);
});
}
);
// function that gets the playlists
function getPlaylists(playlistId)
{
$.get(
"https://www.googleapis.com/youtube/v3/playlistItems",
{
part: 'snippet',
maxResults: vidResults,
playlistId: playlistId,
key: 'xxx'
},
// print the results
function(data)
{
var output;
$.each(data.items,
function(i, item) {
console.log(item);
var vidTitle = item.snippet.title; // video title
var vidDesc = item.snippet.description; // video description
var videoId = item.snippet.resourceId.videoId; // video id
// check if description is empty
if(vidDesc == null || vidDesc == "")
{
vidDesc = "No description was written."; // FIX: test msg to see where it still shows up
$('#desc').remove(); // remove video description
}
else vidDesc = item.snippet.description;
getVideoDuration(videoId).done(function(d, v){
vidDuration = d;
//console.log(r);
viewCount = v;
document.write("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
document.write("<br>");
output = '<li><iframe height="' + vidHeight + '" width="' + vidWidth + '" src=\"//www.youtube.com/embed/' + videoId + '\"></iframe></li><div id="title">' + vidTitle + '</div><div id="desc">' + vidDesc + '</div><div id="duration">Length: ' + vidDuration + '</div><div id="stats">View Count: ' + viewCount + '</div>';
// Append results to list tag
$('#results').append(output);
});
});
}
);
}
// return video duration
function getVideoDuration(videoId)
{
var dfrd1 = $.Deferred();
var r = '';
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails',
id: videoId,
key: 'xxx',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
var view = 0;
r = item.contentDetails.duration; // video duration
getViewCount(videoId).done(function(t){
view = t;
dfrd1.resolve(r, view);
});
//alert(videoId);
});
}
);
return dfrd1.promise();
}
// return video view count
function getViewCount(videoId)
{
var dfrd2 = $.Deferred();
var r = '';
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails, statistics',
id: videoId,
key: 'xxx',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
r = item.statistics.viewCount; // view count
//alert(videoId);
dfrd2.resolve(r);
// console.log("in", r);
});
}
);
return dfrd2.promise();
}
});
编辑
换句话说,这是一个异步方法调用。
getVideoDuration(videoId).done(function(r)
解释:
调用函数 getVideoDuration
和 .done
告诉函数 getVideoDuration
将 return 当我们解决承诺时的结果 (dfrd1.resolve(r);
)。与此同时,函数 return dfrd1.promise();
意味着结果将被推迟。
当 promise 得到解决时,我们输入 done
,然后我们就可以完成剩下的事情了:)
您在屏幕截图中看到的是合乎逻辑的,因为有两个 Promise!
我的错误是我没有看到重复的输入行。
我更改代码来解决这个问题。
所以第一个函数 getVideoDuration
将被解析,然后是第二个。 当第二个函数被解析时我们解析第一个承诺将结果发送到函数getPlaylists(playlistId)
编辑 25/02
我更改了有关承诺错误的代码。
我正在尝试为每个视频检索 duration
和 viewCount
的值,它们都在 videos:list api 下。我创建了一个单独的函数,它将 return 每个视频持续时间和统计信息。唯一有效的是检索到的视频播放列表和 getPlaylist(...)
函数中的 videoId
。我登录到控制台,这就是我得到的:
console.log("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
id: xxx duration: undefined viewCount: undefined
我从来没有工作的时间,但我注意到 api 和 part: statistics
将从注释掉的频道中检索观看次数总和的值。但这不是我要找的。我希望它与每个视频一起使用:
GET https://www.googleapis.com/youtube/v3/videos
但出于某种原因,我无法让它工作。我有 videoId
属性 和作为参数,所以 playlistId 可以读取它并检索视频持续时间和观看次数的所述值,但它仍然未定义,即使 videoId
已经定义。哦,警报对话框也没有出现。
我在这里错过了什么?
脚本:
var channelName = 'ExampleChannel';
var vidWidth = 500;
var vidHeight = 400;
var vidResults = 15; /* # of videos to show at once - max 50 */
var vidDuration = "";
var viewCount = 0;
var videoId = "";
$(document).ready(function() {
$.get( // get channel name and load data
"https://www.googleapis.com/youtube/v3/channels",
{
part: 'contentDetails',
forUsername: channelName,
key: 'XXXXXXXXXX'
},
function(data)
{
$.each(data.items,
function(i, item) {
console.log(item); // log all items to console
var playlistId = item.contentDetails.relatedPlaylists.uploads;
//var viewCount = console.log(item.statistics.viewCount);
getPlaylists(playlistId);
})
}
);
// function that gets the playlists
function getPlaylists(playlistId)
{
$.get(
"https://www.googleapis.com/youtube/v3/playlistItems",
{
part: 'snippet',
maxResults: vidResults,
playlistId: playlistId,
key: 'XXXXXXXXXX'
},
// print the results
function(data)
{
var output;
$.each(data.items,
function(i, item) {
console.log(item);
var vidTitle = item.snippet.title; // video title
var vidDesc = item.snippet.description; // video description
var videoId = item.snippet.resourceId.videoId; // video id
// check if description is empty
if(vidDesc == null || vidDesc == "")
{
vidDesc = "No description was written."; // FIX: test msg to see where it still shows up
$('#desc').remove(); // remove video description
}
else vidDesc = item.snippet.description;
vidDuration = getVideoDuration(videoId);
viewCount = getViewCount(videoId);
console.log("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
output = '<li><iframe height="' + vidHeight + '" width="' + vidWidth + '" src=\"//www.youtube.com/embed/' + videoId + '\"></iframe></li><div id="title">' + vidTitle + '</div><div id="desc">' + vidDesc + '</div><div id="duration">Length: ' + vidDuration + '</div><div id="stats">View Count: ' + viewCount + '</div>';
// Append results to list tag
$('#results').append(output);
})
}
);
}
// return video duration
function getVideoDuration(videoId)
{
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails',
id: videoId,
key: 'XXXXXXXXXX',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
alert(item.contentDetails.duration); // video duration
//alert(videoId);
})
}
);
}
// return video view count
function getViewCount(videoId)
{
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails, statistics',
id: videoId,
key: 'XXXXXXXXXX',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
alert(item.statistics.viewCount); // view count
//alert(videoId);
})
}
);
}
});
截图:(更新)
因为当您调用这些函数时,您不会等待函数完成。 您需要在 Javascript.
中使用 Promise我稍微更改了您的代码(使用我的 api 密钥进行了测试)
var channelName = 'example';
var vidWidth = 500;
var vidHeight = 400;
var vidResults = 15; /* # of videos to show at once - max 50 */
var vidDuration = "";
var viewCount = 0;
var videoId = "";
$(document).ready(function() {
$.get( // get channel name and load data
"https://www.googleapis.com/youtube/v3/channels",
{
part: 'contentDetails',
forUsername: channelName,
key: 'xxx'
},
function(data)
{
$.each(data.items,
function(i, item) {
//console.log(item); // log all items to console
var playlistId = item.contentDetails.relatedPlaylists.uploads;
//var viewCount = console.log(item.statistics.viewCount);
getPlaylists(playlistId);
});
}
);
// function that gets the playlists
function getPlaylists(playlistId)
{
$.get(
"https://www.googleapis.com/youtube/v3/playlistItems",
{
part: 'snippet',
maxResults: vidResults,
playlistId: playlistId,
key: 'xxx'
},
// print the results
function(data)
{
var output;
$.each(data.items,
function(i, item) {
console.log(item);
var vidTitle = item.snippet.title; // video title
var vidDesc = item.snippet.description; // video description
var videoId = item.snippet.resourceId.videoId; // video id
// check if description is empty
if(vidDesc == null || vidDesc == "")
{
vidDesc = "No description was written."; // FIX: test msg to see where it still shows up
$('#desc').remove(); // remove video description
}
else vidDesc = item.snippet.description;
getVideoDuration(videoId).done(function(d, v){
vidDuration = d;
//console.log(r);
viewCount = v;
document.write("id: " + videoId + " duration: " + vidDuration + " viewCount: " + viewCount); // return value in console
document.write("<br>");
output = '<li><iframe height="' + vidHeight + '" width="' + vidWidth + '" src=\"//www.youtube.com/embed/' + videoId + '\"></iframe></li><div id="title">' + vidTitle + '</div><div id="desc">' + vidDesc + '</div><div id="duration">Length: ' + vidDuration + '</div><div id="stats">View Count: ' + viewCount + '</div>';
// Append results to list tag
$('#results').append(output);
});
});
}
);
}
// return video duration
function getVideoDuration(videoId)
{
var dfrd1 = $.Deferred();
var r = '';
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails',
id: videoId,
key: 'xxx',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
var view = 0;
r = item.contentDetails.duration; // video duration
getViewCount(videoId).done(function(t){
view = t;
dfrd1.resolve(r, view);
});
//alert(videoId);
});
}
);
return dfrd1.promise();
}
// return video view count
function getViewCount(videoId)
{
var dfrd2 = $.Deferred();
var r = '';
$.get(
"https://www.googleapis.com/youtube/v3/videos",
{
part: 'contentDetails, statistics',
id: videoId,
key: 'xxx',
},
function(data)
{
$.each(data.items,
function(i, item) {
//videoId = item.snippet.resourceId.videoId;
r = item.statistics.viewCount; // view count
//alert(videoId);
dfrd2.resolve(r);
// console.log("in", r);
});
}
);
return dfrd2.promise();
}
});
编辑
换句话说,这是一个异步方法调用。
getVideoDuration(videoId).done(function(r)
解释:
调用函数 getVideoDuration
和 .done
告诉函数 getVideoDuration
将 return 当我们解决承诺时的结果 (dfrd1.resolve(r);
)。与此同时,函数 return dfrd1.promise();
意味着结果将被推迟。
当 promise 得到解决时,我们输入 done
,然后我们就可以完成剩下的事情了:)
您在屏幕截图中看到的是合乎逻辑的,因为有两个 Promise!
我的错误是我没有看到重复的输入行。
我更改代码来解决这个问题。
所以第一个函数 getVideoDuration
将被解析,然后是第二个。 当第二个函数被解析时我们解析第一个承诺将结果发送到函数getPlaylists(playlistId)
编辑 25/02
我更改了有关承诺错误的代码。