拉youtube视频的统计和持续时间数据的饲料



我目前正在尝试使用Youtube V3 API来生成一个频道中最近上传的视频的提要。目前我已经得到了这个大部分工作,但是我不能为我的生活得到两个重要的数据拉过-视频视图和视频持续时间。我知道这些数据属于"视频"端点,但我不确定如何将其集成到谷歌Youtube API网站上提供的Javascript API示例中。下面是我的代码-任何帮助将非常感激:

// Define some variables used to remember state.
var playlistId, nextPageToken, prevPageToken;
// After the API loads, call a function to get the uploads playlist ID.
function handleAPILoaded() {
  requestUserUploadsPlaylistId();
}
// Call the Data API to retrieve the playlist ID that uniquely identifies the
// list of videos uploaded to the currently authenticated user's channel.
function requestUserUploadsPlaylistId() {
  // See https://developers.google.com/youtube/v3/docs/channels/list
  var request = gapi.client.youtube.channels.list({
    mine: true,
    part: 'contentDetails, statistics'
  });
  request.execute(function(response) {
    playlistId = response.result.items[0].contentDetails.relatedPlaylists.uploads;
    requestVideoPlaylist(playlistId);
  });
}
// Retrieve the list of videos in the specified playlist.
function requestVideoPlaylist(playlistId, pageToken) {
  $('#video-container').html('');
  var requestOptions = {
    playlistId: playlistId,
    part: 'snippet, contentDetails',
    maxResults: 10
  };
  if (pageToken) {
    requestOptions.pageToken = pageToken;
  }
  var request = gapi.client.youtube.playlistItems.list(requestOptions);
  request.execute(function(response) {
    // Only show pagination buttons if there is a pagination token for the
    // next or previous page of results.
    nextPageToken = response.result.nextPageToken;
    var nextVis = nextPageToken ? 'visible' : 'hidden';
    $('#next-button').css('visibility', nextVis);
    prevPageToken = response.result.prevPageToken
    var prevVis = prevPageToken ? 'visible' : 'hidden';
    $('#prev-button').css('visibility', prevVis);
    var playlistItems = response.result.items;
    if (playlistItems) {
      $.each(playlistItems, function(index, item) {
        displayResult(item.snippet);
        displayContentDetails(item.contentDetails);
        displayStats(item.statistics);
      });
    } else {
      $('#video-container').html('Sorry you have no uploaded videos');
    }
  });
}
// Create a listing for a video.
function displayResult(videoSnippet) {
  var title = videoSnippet.title;
  var videoId = videoSnippet.resourceId.videoId;
  var publishedAt = videoSnippet.publishedAt;
  var videoThumbURL = videoSnippet.thumbnails.high.url;
  var publishedUTC = new Date(publishedAt);
  var publishedDay = publishedUTC.getUTCDay();
  var publishedMonth = publishedUTC.getUTCMonth();
  var publishedYear = publishedUTC.getUTCFullYear();
  var a = moment(publishedUTC);
  var b = moment(Date.now());
  var timeFrom = a.from(b);
  $('#video-container').append('<a href="https://youtu.be/'+ videoId +'"><li><img src='+videoThumbURL+'><br><p>' + title + ' - ' + timeFrom + '</p></li></a>');
}
// Create a listing for a video.
function displayContentDetails(stuff) {
  var videoEndsAt = stuff.duration;
  $('#video-container li').append('<span class="endsAt">'+ videoEndsAt +'</span>');
}
function displayStats(vidStats) {
  var videoStats = vidStats.viewCount;
  $('#video-container li').append('<span class="videoStats">'+ videoStats +'</span>');
}

// Retrieve the next page of videos in the playlist.
function nextPage() {
  requestVideoPlaylist(playlistId, nextPageToken);
}
// Retrieve the previous page of videos in the playlist.
function previousPage() {
  requestVideoPlaylist(playlistId, prevPageToken);
}

虽然您说的是channel,但代码显示您从播放列表中提取,该列表没有您想要的数据。

对于来自播放列表的每个视频,您需要保存videoID,然后使用'snippet,contentDetails,statistics'的'parts'参数调用Videos: list端点(一次最多50个id)。这些API结果将包含您想要的数据。

谢谢@Johnh10,你是对的,这就是我最后做的。

  var videoStatsEndpoint = "https://www.googleapis.com/youtube/v3/videos?part=statistics";
  var videoToQuery = "&id="+videoId+"&key=";
  var apiKey = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
  var videoViews = 0;
  jQuery.get(videoStatsEndpoint + videoToQuery + apiKey, function(data){
    videoViews = data.items[0].statistics.viewCount;
    console.log(videoViews);
  });