نمونههای کد Apps Script زیر برای YouTube Data API موجود است. میتوانید این نمونههای کد را از پوشه apps-script
مخزن نمونه کد YouTube APIs در GitHub دانلود کنید.
بارگذاری های من را بازیابی کنید
این تابع ویدیوهای آپلود شده کاربر اسکریپت فعلی را بازیابی می کند. برای اجرا، به محدوده خواندن/نوشتن OAuth برای YouTube و همچنین مجوز کاربر نیاز دارد. در محیط اجرای برنامههای اسکریپت، اولین باری که کاربر یک اسکریپت را اجرا میکند، Apps Script از کاربر اجازه میدهد تا به خدماتی که توسط اسکریپت فراخوانی میشود، دسترسی داشته باشد. پس از اعطای مجوزها، آنها برای مدتی در حافظه پنهان ذخیره می شوند. پس از تغییر مجوزهای مورد نیاز یا زمانی که توسط تابعScriptApp.invalidateAuth()
باطل شوند، از کاربری که اسکریپت را اجرا می کند، دوباره درخواست مجوز می شود.این اسکریپت مراحل زیر را برای بازیابی ویدیوهای آپلود شده کاربر فعال انجام می دهد:
- کانال های کاربر را واکشی می کند.
- لیست پخش "آپلود" کاربر را واکشی می کند.
- از طریق این لیست پخش تکرار می شود و شناسه ها و عناوین ویدیو را ثبت می کند.
- در صورت وجود نشانه صفحه بعدی را واکشی می کند. اگر وجود دارد، صفحه بعدی را واکشی می کند. مرحله 3 را تکرار کنید.
/** * This function retrieves the current script user's uploaded videos. To execute, * it requires the OAuth read/write scope for YouTube as well as user authorization. * In Apps Script's runtime environment, the first time a user runs a script, Apps * Script will prompt the user for permission to access the services called by the * script. After permissions are granted, they are cached for some periodF of time. * The user running the script will be prompted for permission again once the * permissions required change, or when they are invalidated by the * ScriptApp.invalidateAuth() function. * * This script takes the following steps to retrieve the active user's uploaded videos: * 1. Fetches the user's channels * 2. Fetches the user's 'uploads' playlist * 3. Iterates through this playlist and logs the video IDs and titles * 4. Fetches a next page token (if any). If there is one, fetches the next page. GOTO Step 3 */ function retrieveMyUploads() { var results = YouTube.Channels.list('contentDetails', {mine: true}); for(var i in results.items) { var item = results.items[i]; // Get the playlist ID, which is nested in contentDetails, as described in the // Channel resource: https://developers.google.com/youtube/v3/docs/channels var playlistId = item.contentDetails.relatedPlaylists.uploads; var nextPageToken = ''; // This loop retrieves a set of playlist items and checks the nextPageToken in the // response to determine whether the list contains additional items. It repeats that process // until it has retrieved all of the items in the list. while (nextPageToken != null) { var playlistResponse = YouTube.PlaylistItems.list('snippet', { playlistId: playlistId, maxResults: 25, pageToken: nextPageToken }); for (var j = 0; j < playlistResponse.items.length; j++) { var playlistItem = playlistResponse.items[j]; Logger.log('[%s] Title: %s', playlistItem.snippet.resourceId.videoId, playlistItem.snippet.title); } nextPageToken = playlistResponse.nextPageToken; } } }
جستجو بر اساس کلمه کلیدی
این تابع ویدیوهای مرتبط با کلمه کلیدی'dogs'
را جستجو می کند. شناسههای ویدیویی و عناوین نتایج جستجو در گزارش Apps Script ثبت میشوند.توجه داشته باشید که این نمونه نتایج را به 25 محدود می کند. برای برگرداندن نتایج بیشتر، پارامترهای اضافی را همانطور که در Search:list مستند شده است، ارسال کنید.
/** * This function searches for videos related to the keyword 'dogs'. The video IDs and titles * of the search results are logged to Apps Script's log. * * Note that this sample limits the results to 25. To return more results, pass * additional parameters as documented here: * https://developers.google.com/youtube/v3/docs/search/list */ function searchByKeyword() { var results = YouTube.Search.list('id,snippet', {q: 'dogs', maxResults: 25}); for(var i in results.items) { var item = results.items[i]; Logger.log('[%s] Title: %s', item.id.videoId, item.snippet.title); } }
جستجو بر اساس موضوع
این تابع به جستجوی ویدیوهایی میپردازد که با موضوع Freebase خاصی مرتبط هستند، شناسهها و عناوین ویدیوی آنها را در گزارش Apps Script ثبت میکند. این مثال از شناسه موضوع برای Google Apps Script استفاده می کند.توجه داشته باشید که این نمونه نتایج را به 25 محدود می کند. برای برگرداندن نتایج بیشتر، پارامترهای اضافی را همانطور که در Search:list مستند شده است، ارسال کنید.
/** * This function searches for videos that are associated with a particular Freebase * topic, logging their video IDs and titles to the Apps Script log. This example uses * the topic ID for Google Apps Script. * * Note that this sample limits the results to 25. To return more results, pass * additional parameters as documented here: * https://developers.google.com/youtube/v3/docs/search/list */ function searchByTopic() { var mid = '/m/0gjf126'; var results = YouTube.Search.list('id,snippet', {topicId: mid, maxResults: 25}); for(var i in results.items) { var item = results.items[i]; Logger.log('[%s] Title: %s', item.id.videoId, item.snippet.title); } }
عضو کانال شوید
این نمونه کاربر فعال را در کانال YouTube Developers Google که توسط channelId مشخص شده است مشترک می کند./** * This sample subscribes the active user to the Google Developers * YouTube channel, specified by the channelId. */ function addSubscription() { // Replace this channel ID with the channel ID you want to subscribe to var channelId = 'UC_x5XG1OV2P6uZZ5FSM9Ttw'; var resource = { snippet: { resourceId: { kind: 'youtube#channel', channelId: channelId } } }; try { var response = YouTube.Subscriptions.insert(resource, 'snippet'); Logger.log(response); } catch (e) { if(e.message.match('subscriptionDuplicate')) { Logger.log('Cannot subscribe; already subscribed to channel: ' + channelId); } else { Logger.log('Error adding subscription: ' + e.message); } } }
ویدیو را به روز کنید
این نمونه آپلودهای کاربر فعال را پیدا می کند، سپس با اضافه کردن یک رشته، آخرین توضیحات آپلود را به روز می کند./** * This sample finds the active user's uploads, then updates the most recent * upload's description by appending a string. */ function updateVideo() { // 1. Fetch all the channels owned by active user var myChannels = YouTube.Channels.list('contentDetails', {mine: true}); // 2. Iterate through the channels and get the uploads playlist ID for (var i = 0; i < myChannels.items.length; i++) { var item = myChannels.items[i]; var uploadsPlaylistId = item.contentDetails.relatedPlaylists.uploads; var playlistResponse = YouTube.PlaylistItems.list('snippet', { playlistId: uploadsPlaylistId, maxResults: 1 }); // Get the videoID of the first video in the list var video = playlistResponse.items[0]; var originalDescription = video.snippet.description; var updatedDescription = originalDescription + ' Description updated via Google Apps Script'; video.snippet.description = updatedDescription; var resource = { snippet: { title: video.snippet.title, description: updatedDescription, categoryId: '22' }, id: video.snippet.resourceId.videoId }; YouTube.Videos.update(resource, 'id,snippet'); } }