YouTube 自动化
高级
这是一个AI, Marketing领域的自动化工作流,包含 33 个节点。主要使用 If, Set, Code, Wait, YouTube 等节点,结合人工智能技术实现智能自动化。 自动化 YouTube 视频排程和 AI 元数据生成 🎬
前置要求
- •可能需要目标 API 的认证凭证
- •OpenAI API Key
- •Google Gemini API Key
使用的节点 (33)
工作流预览
可视化展示节点连接关系,支持缩放和平移
导出工作流
复制以下 JSON 配置到 n8n 导入,即可使用此工作流
{
"id": "wLbJ7rE6vQzizCp2",
"meta": {
"instanceId": "5ce52989094be90be3b3bdd9ed9cee1d7ce1fcecaa598afaec4a50646d32e291",
"templateCredsSetupCompleted": true
},
"name": "YouTube_自动化",
"tags": [
{
"id": "5eZb3e5PJspoJjVN",
"name": "Privat",
"createdAt": "2025-02-22T09:31:58.972Z",
"updatedAt": "2025-02-22T09:31:58.972Z"
},
{
"id": "fSDcaaN3w5sV5e3S",
"name": "Templates",
"createdAt": "2025-02-23T15:20:47.262Z",
"updatedAt": "2025-02-23T15:20:47.262Z"
}
],
"nodes": [
{
"id": "2001b9ca-f76b-437e-90a9-16c0d17accef",
"name": "获取最新视频",
"type": "n8n-nodes-base.youTube",
"position": [
-60,
40
],
"parameters": {
"limit": 1,
"filters": {},
"options": {
"order": "date"
},
"resource": "video"
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
},
{
"id": "e8857adf-63ec-4612-aa49-cd77130a6728",
"name": "遍历项目",
"type": "n8n-nodes-base.splitInBatches",
"position": [
160,
40
],
"parameters": {
"options": {}
},
"typeVersion": 3
},
{
"id": "1a8cf640-caf4-4163-a658-400714702314",
"name": "YouTube 标题",
"type": "@n8n/n8n-nodes-langchain.openAi",
"disabled": true,
"position": [
2220,
120
],
"parameters": {
"modelId": {
"__rl": true,
"mode": "list",
"value": "gpt-4.1-nano",
"cachedResultName": "GPT-4.1-NANO"
},
"options": {},
"messages": {
"values": [
{
"role": "system",
"content": "Du bist ein professioneller Texter für SEO-optimierte YouTube-Titel."
},
{
"content": "=Schreib mir einen passenden SEO Youtube Titel für das Transkript folgendes Videotranskriptes. Gib mir nur den Titel sonst nichts. Maximal 100 Character also halte dich kurz.\n\n{{ $('Adjust Transcript Format').item.json.transcript }}"
}
]
}
},
"credentials": {
"openAiApi": {
"id": "ftBgqCi1fD1fFEZq",
"name": "Midgard#1"
}
},
"typeVersion": 1.7
},
{
"id": "ec6e5d83-d8c8-417e-8df0-86634feef3e6",
"name": "创建描述",
"type": "@n8n/n8n-nodes-langchain.openAi",
"position": [
1920,
80
],
"parameters": {
"modelId": {
"__rl": true,
"mode": "list",
"value": "gpt-4.1-nano",
"cachedResultName": "GPT-4.1-NANO"
},
"options": {},
"messages": {
"values": [
{
"role": "system",
"content": "Du bist ein professioneller Texteschreiber.\nDu erhältst das Transkript eines wirtschaftsbezogenen Videos und erstellst eine ausführlichere aber auch nicht zu lange Zusammenfassung (mit Absätzen) darüber, worum es geht.\n\nSchreibe eine ausführlichere Zusammenfassung (mit Absätzen) über den Inhalt des Podcasts. \n\nDein Output wird für die Youtube Video Beschreibung verwendet. Also starte mit sowas wie: \"In diesem Video...\" oder \"In dieser Folge...\". \nSchreibe aus meiner Perspektive also Sachen wie \"meine Meinung\" oder \"meiner Ansicht nach\"... aus der Ich- Perspektive aber niemals sowas wie \"In dieser Folge lerne ich...\" oder so ähnlich, denn ich erkläre stets den Inhalt bzw. diskutiere darüber. DU SCHREIBST NIEMALS SOWAS WIE \"DER SPRECHER SAGT\"!!! Immer aus meiner Position heraus.\n\nWichtig: Verwende klare und dominante Aussagen, wie sie im Transkript formuliert sind. Vermeide neutrale oder unsichere Formulierungen wie \"es könnte\", \"ich vermute, dass\", \"möglicherweise\" oder ähnliche Phrasen. Die Aussagen sollen selbstbewusst und eindeutig sein, um die Inhalte des Podcasts kraftvoll zu vermitteln.\nFüge einige wenige (2-4) Emojis an wo es sich anbietet. \n \nEnde den Post mit 2-5 passenden Hashtags. Die Hashtags sollten grob sein also sowas wie #wirtschaft #geld #gold oder so ähnlich - je nachdem was passt.\n"
},
{
"content": "=Hier ist das Transkript: \n\n{{ $json.transcript }}"
}
]
}
},
"credentials": {
"openAiApi": {
"id": "ftBgqCi1fD1fFEZq",
"name": "Midgard#1"
}
},
"typeVersion": 1.7
},
{
"id": "f59d950b-4e29-4a41-8756-85ea7814b3d3",
"name": "当点击\"测试工作流\"时",
"type": "n8n-nodes-base.manualTrigger",
"position": [
-2260,
300
],
"parameters": {},
"typeVersion": 1
},
{
"id": "27ef7d44-7cca-417f-8177-b5b896a79aa0",
"name": "便签1",
"type": "n8n-nodes-base.stickyNote",
"position": [
2660,
-20
],
"parameters": {
"color": 3,
"width": 220,
"content": "### 🎥标题保留自上传内容,或者您可以在流程中添加 YT 标题模块"
},
"typeVersion": 1
},
{
"id": "8d763312-35f0-4d53-a210-1e0e22a06323",
"name": "便签2",
"type": "n8n-nodes-base.stickyNote",
"position": [
1920,
-140
],
"parameters": {
"color": 3,
"height": 200,
"content": "# 调整提示 👉🏻"
},
"typeVersion": 1
},
{
"id": "9e7f22d5-7776-4bc4-a274-963cb8c8810c",
"name": "便签3",
"type": "n8n-nodes-base.stickyNote",
"position": [
-540,
-560
],
"parameters": {
"color": 5,
"width": 620,
"height": 420,
"content": "# YouTube 视频描述/标签等自动化"
},
"typeVersion": 1
},
{
"id": "4c5667cf-f8a9-45ab-876b-3a6b5730484c",
"name": "2.5FlashPrev",
"type": "@n8n/n8n-nodes-langchain.lmChatGoogleGemini",
"position": [
2220,
0
],
"parameters": {
"options": {},
"modelName": "models/gemini-2.5-flash-preview-04-17"
},
"credentials": {
"googlePalmApi": {
"id": "clmB8ZYJMHaHmnsu",
"name": "Stardawn#1"
}
},
"typeVersion": 1
},
{
"id": "7c73cc89-ea8e-42b3-a1c9-2dc493026216",
"name": "YouTube 标签",
"type": "@n8n/n8n-nodes-langchain.agent",
"position": [
2220,
-120
],
"parameters": {
"text": "=Nun folgt das eigentliche Thema/Transkript. Gib mir die Youtube Tags dafür:\n\n{{ $('Adjust Transcript Format').item.json.transcript }}",
"options": {
"systemMessage": "You will get the transcript of a Youtube video for which you should generate matching tags (YOU NEED TO separate it by comma).\n\nBased on the topic/transcript of the video generate YouTube tags. These tags should be very general about the topics. Give multiple matching YouTube Tags that improve SEO for the video. \n\nExample:\nif the video is about why gold is a good investment you will for example not use gold investments as a tag but rather just gold \n\nThe tags (if appropriate) should be in German as the channel content is in German.\n\nReturn just the tags one word by one separated via Comma. \n\n\nDieses Video handelt vom zukünftigen Goldpreis und davon, wie er die Renditen von performanten Vermögenswerten wie Aktien und Anleihen in ihrer angepassten Rendite beeinflusst.\n\nErwartetet output:\nGoldpreis, zukünftiger Goldpreis, Goldinvestitionen, Vermögensrenditen, Aktien und Anleihen, Investitionsrenditen, angepasste Rendite, Goldmarkt, Finanzmärkte, Goldpreisprognose, Wirtschaftstrends, Investieren in Gold, Aktienmarktanalyse, Anleihenmarkt, Anlagestrategien, Inflation und Gold, Gold vs. Aktien, Finanzanalyse, Edelmetalle, Portfoliomanagement, Marktausblick, Investmenttipps\n "
},
"promptType": "define"
},
"typeVersion": 1.9
},
{
"id": "e8782ac7-ca31-4a5f-a9f1-62548f56407d",
"name": "便签4",
"type": "n8n-nodes-base.stickyNote",
"position": [
-2340,
-140
],
"parameters": {
"color": 4,
"width": 2000,
"height": 660,
"content": "# 📅调度逻辑⏰"
},
"typeVersion": 1
},
{
"id": "33d289eb-c989-4c8d-b387-405f31ba11d6",
"name": "3秒",
"type": "n8n-nodes-base.wait",
"position": [
2920,
140
],
"webhookId": "1e75fe1f-e553-4530-a8bc-5e64208a1184",
"parameters": {
"amount": 3
},
"typeVersion": 1.1
},
{
"id": "19337563-a349-485d-a064-32f58c8fde90",
"name": "获取标题",
"type": "n8n-nodes-base.youTube",
"position": [
-780,
200
],
"parameters": {
"options": {},
"videoId": "={{ $json.videoId }}",
"resource": "video",
"operation": "get"
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
},
{
"id": "da93ff18-8d19-45ab-b268-dbbebcb86719",
"name": "便签",
"type": "n8n-nodes-base.stickyNote",
"position": [
-1040,
-140
],
"parameters": {
"color": 5,
"width": 180,
"content": "## 代码仅返回未列出的视频"
},
"typeVersion": 1
},
{
"id": "71e9606c-4b6e-4b49-b3ec-bd9bd261f7a9",
"name": "便签5",
"type": "n8n-nodes-base.stickyNote",
"position": [
-600,
-80
],
"parameters": {
"color": 3,
"width": 220,
"height": 260,
"content": "## 视频需要设置为私密并与 PublishAt 参数一起使用才能正常工作"
},
"typeVersion": 1
},
{
"id": "c5a240aa-b705-4219-b293-da4ae0168350",
"name": "便签6",
"type": "n8n-nodes-base.stickyNote",
"position": [
1320,
-140
],
"parameters": {
"color": 3,
"width": 280,
"height": 240,
"content": "### 视频需要设置为未列出或已发布,爬虫才能获取字幕"
},
"typeVersion": 1
},
{
"id": "5fb12ed7-8992-424d-86e0-7c8cd0f0b9d3",
"name": "便签7",
"type": "n8n-nodes-base.stickyNote",
"position": [
-80,
-140
],
"parameters": {
"color": 4,
"width": 3200,
"height": 660,
"content": "# 生成描述、标签等 🖌️📝 #️⃣"
},
"typeVersion": 1
},
{
"id": "33b865ef-ec2e-4349-bbba-d76d41345fe3",
"name": "设置发布日期",
"type": "n8n-nodes-base.youTube",
"position": [
-600,
280
],
"parameters": {
"title": "={{ $json.snippet.title }}",
"videoId": "={{ $json.id }}",
"resource": "video",
"operation": "update",
"categoryId": "25",
"regionCode": "DE",
"updateFields": {
"publishAt": "={{ $('Loop over All Videos not Published').item.json.publishAt }}",
"privacyStatus": "private"
}
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
},
{
"id": "9a228886-c91a-44f7-b894-e23095166efc",
"name": "每天",
"type": "n8n-nodes-base.scheduleTrigger",
"disabled": true,
"position": [
-2260,
60
],
"parameters": {
"rule": {
"interval": [
{
"triggerAtHour": 14,
"triggerAtMinute": 22
}
]
}
},
"typeVersion": 1.2
},
{
"id": "c0277051-f146-43f7-a2cd-36739d933209",
"name": "获取要重新调度的视频",
"type": "n8n-nodes-base.youTube",
"position": [
-1880,
40
],
"parameters": {
"limit": 2,
"filters": {},
"options": {
"order": "date"
},
"resource": "video"
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
},
{
"id": "5cf3813b-931b-4c0a-84fe-4edd3d55a99a",
"name": "获取分离的视频 ID",
"type": "n8n-nodes-base.code",
"position": [
-1660,
40
],
"parameters": {
"jsCode": "// Extract video IDs from YouTube search results\n// This function processes all input items and creates separate items for each videoId\n\n// Initialize empty array for our result items\nconst resultItems = [];\n\n// Process each input item\nfor (const item of items) {\n // Check if the item has a valid structure\n if (item.json && item.json.id && item.json.id.videoId) {\n // Create a new item for each videoId\n resultItems.push({\n json: {\n videoId: item.json.id.videoId\n }\n });\n }\n}\n\n// Return each videoId as a separate item that can be processed individually\nreturn resultItems;"
},
"typeVersion": 2
},
{
"id": "8131b388-b842-4c46-b82b-e53283d938ed",
"name": "循环处理视频 ID",
"type": "n8n-nodes-base.splitInBatches",
"position": [
-1440,
40
],
"parameters": {
"options": {}
},
"typeVersion": 3
},
{
"id": "665cb406-f6b9-4ba4-82fa-daa1141eb0a3",
"name": "获取视频数据",
"type": "n8n-nodes-base.youTube",
"position": [
-1220,
60
],
"parameters": {
"options": {},
"videoId": "={{ $json.videoId }}",
"resource": "video",
"operation": "get"
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
},
{
"id": "3d366fb3-f579-46f0-9254-8d4c1612038e",
"name": "返回私密视频",
"type": "n8n-nodes-base.code",
"position": [
-1220,
-120
],
"parameters": {
"jsCode": "// Utility function to get next Friday at 17:00 UTC in YouTube ISO 8601 format (YYYY-MM-DDTHH:mm:ssZ)\nfunction getNextFridayUTC(startDate, weekOffset = 0) {\n const date = new Date(startDate); // Work with a copy\n \n const currentUTCDay = date.getUTCDay(); // 0 for Sunday, ..., 5 for Friday\n const daysUntilFriday = (5 - currentUTCDay + 7) % 7; // Calculate days to next Friday\n \n date.setUTCDate(date.getUTCDate() + daysUntilFriday + (weekOffset * 7));\n date.setUTCHours(17, 0, 0, 0); // Set time to 17:00:00.000 UTC\n \n // toISOString() returns \"YYYY-MM-DDTHH:mm:ss.sssZ\"\n // We split at '.' to remove milliseconds and add 'Z' back for \"YYYY-MM-DDTHH:mm:ssZ\"\n return date.toISOString().split('.')[0] + \"Z\";\n}\n\n// INPUT `items` is an array from n8n.\n// Each item.json is expected to be a YouTube video object from a previous node.\nconst videosToSchedule = items.filter(item => \n item.json && \n item.json.status && \n (item.json.status.privacyStatus === \"unlisted\" || item.json.status.privacyStatus === \"private\")\n // Adjust this filter if you only want to process \"unlisted\" or only \"private\" videos\n);\n\nif (videosToSchedule.length === 0) {\n // console.log(\"No videos found matching the filter criteria.\");\n return []; // Return empty array if no videos to schedule\n}\n\n// Sort videos by their original published/uploaded date (snippet.publishedAt), earliest first.\nvideosToSchedule.sort((a, b) => {\n const dateA = new Date(a.json?.snippet?.publishedAt || '1970-01-01T00:00:00Z');\n const dateB = new Date(b.json?.snippet?.publishedAt || '1970-01-01T00:00:00Z');\n return dateA - dateB;\n});\n\nconst now = new Date(); // Current date to calculate future Fridays\n\n// Map the filtered and sorted videos to the desired output structure for the YouTube update node.\nconst scheduledItems = videosToSchedule.map((item, index) => {\n const videoData = item.json; // The actual video data object\n const scheduleDate = getNextFridayUTC(now, index); // Calculate the publishAt date\n \n return {\n json: { // This is the structure the next n8n YouTube node will receive\n videoId: videoData.id, // ID of the video to update\n publishAt: scheduleDate, // The calculated schedule time: YYYY-MM-DDTHH:mm:ssZ\n title: videoData.snippet?.title || \"Untitled Video\", // Keep original title or use a default\n \n // --- CRITICAL PARAMETERS FOR THE YOUTUBE API ---\n privacy: \"private\", // **MUST BE 'private' FOR 'publishAt' TO WORK!**\n // The API requires the video to be set to private when scheduling.\n \n // **VERY LIKELY REQUIRED: selfDeclaredMadeForKids**\n // You MUST tell YouTube if the video is made for kids or not.\n // Get it from existing data if available, otherwise set a default.\n selfDeclaredMadeForKids: videoData.status?.selfDeclaredMadeForKids === true ? true : false,\n\n // **POSSIBLY REQUIRED: categoryId (if updating snippet like title)**\n // categoryId: videoData.snippet?.categoryId || \"YOUR_DEFAULT_CATEGORY_ID\", \n // e.g., \"10\" for Music, \"22\" for People & Blogs.\n // Check YouTube API docs for category IDs.\n \n // (Optional) You can include other fields like description if you want to update them\n // description: videoData.snippet?.description || \"\" \n }\n };\n});\n\nreturn scheduledItems; // Return the array of video objects to be processed"
},
"typeVersion": 2,
"alwaysOutputData": true
},
{
"id": "bb3e90ae-ff3f-4c22-b920-d1a99a1f99e8",
"name": "4秒",
"type": "n8n-nodes-base.wait",
"position": [
-260,
240
],
"webhookId": "7d5c70f8-a592-4634-8c5a-0fbd0cebf6a4",
"parameters": {
"amount": 4
},
"typeVersion": 1.1
},
{
"id": "f67c7668-71eb-42e6-b385-f66f9e5e80eb",
"name": "循环处理所有未发布的视频",
"type": "n8n-nodes-base.splitInBatches",
"position": [
-1020,
60
],
"parameters": {
"options": {}
},
"typeVersion": 3
},
{
"id": "f98b1399-7970-4585-8f2a-be897562fa40",
"name": "获取视频 ID",
"type": "n8n-nodes-base.set",
"position": [
380,
80
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "c2e2eecd-ca73-40c9-a364-4713030ab451",
"name": "id.videoId",
"type": "string",
"value": "={{ $json.id.videoId }}"
}
]
},
"includeOtherFields": true
},
"typeVersion": 3.4
},
{
"id": "6b907512-945b-4c1e-8a97-b14409ddfcaa",
"name": "移除之前运行的重复项",
"type": "n8n-nodes-base.removeDuplicates",
"position": [
600,
80
],
"parameters": {
"options": {},
"operation": "removeItemsSeenInPreviousExecutions",
"dedupeValue": "={{ $json.id.videoId }}"
},
"typeVersion": 2,
"alwaysOutputData": false
},
{
"id": "d6c7152e-e508-43c3-8748-ba12652ac117",
"name": "新视频?",
"type": "n8n-nodes-base.if",
"position": [
820,
80
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "adfea7c7-ed64-4e1e-a9c3-dc5e33aa1147",
"operator": {
"type": "array",
"operation": "notExists",
"singleValue": true
},
"leftValue": "={{$('Remove Duplicates from previous Runs').all() }}",
"rightValue": ""
}
]
}
},
"typeVersion": 2.2
},
{
"id": "d1c31718-4a26-4108-a618-f67cfb87053c",
"name": "获取最新视频 ID",
"type": "n8n-nodes-base.youTube",
"position": [
1000,
160
],
"parameters": {
"options": {},
"videoId": "={{ $('get video id').item.json.id.videoId }}",
"resource": "video",
"operation": "get"
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1,
"alwaysOutputData": true
},
{
"id": "66814975-e4a5-4c23-9bf2-c8d30d96c122",
"name": "获取转录文本",
"type": "n8n-nodes-base.httpRequest",
"position": [
1320,
120
],
"parameters": {
"url": "=https://api.apify.com/v2/acts/pintostudio~youtube-transcript-scraper/run-sync-get-dataset-items",
"method": "POST",
"options": {},
"jsonBody": "={\n \"videoUrl\": \"https://www.youtube.com/watch?v={{ $json.id }}\"\n}",
"sendBody": true,
"sendQuery": true,
"specifyBody": "json",
"queryParameters": {
"parameters": [
{
"name": "token",
"value": "YOURAPITOKEN"
}
]
}
},
"typeVersion": 4.2,
"alwaysOutputData": false
},
{
"id": "fd355571-8c74-4d31-972e-13f737aaec05",
"name": "调整字幕格式",
"type": "n8n-nodes-base.code",
"position": [
1600,
120
],
"parameters": {
"jsCode": "const items = $input.all();\n\nconst transcriptStrings = items.flatMap(item => {\n const dataArray = item.json.data;\n\n if (!dataArray || !Array.isArray(dataArray)) {\n return [];\n }\n\n const segmentTexts = dataArray.map(segment => {\n if (segment && typeof segment.text === 'string') {\n return segment.text;\n } else {\n return '';\n }\n });\n\n return segmentTexts;\n});\n\nconst transcript = transcriptStrings.join(' ');\n\nreturn [\n {\n json: {\n transcript: transcript,\n },\n },\n];"
},
"typeVersion": 2
},
{
"id": "7b69339f-aa12-430e-ba21-b85a0db596b5",
"name": "更新视频元数据",
"type": "n8n-nodes-base.youTube",
"position": [
2660,
140
],
"parameters": {
"title": "={{ $('Fetch Latest Videos').first().json.snippet.title }}",
"videoId": "={{ $('getLatestVideoID').first().json.id }}",
"resource": "video",
"operation": "update",
"categoryId": "25",
"regionCode": "DE",
"updateFields": {
"tags": "={{ $('YT Tags').first().json.message.content }}",
"description": "={{ $('Create Description').first().json.message.content }}\n\nDiese textbasierte Zusammenfassung des Videos wurde automatisch mit dem KI-Modell gpt-4.1-nano erstellt.]\n"
}
},
"credentials": {
"youTubeOAuth2Api": {
"id": "cpgVAMXp8iMLXwKW",
"name": "Private Pres"
}
},
"typeVersion": 1
}
],
"active": true,
"pinData": {},
"settings": {
"callerPolicy": "workflowsFromSameOwner",
"errorWorkflow": "RhPW7iLQQJGJZqQQ",
"executionOrder": "v1"
},
"versionId": "268a8dc5-0408-458c-9dff-d7c91b223b76",
"connections": {
"3s": {
"main": [
[
{
"node": "Loop Over Items",
"type": "main",
"index": 0
}
]
]
},
"4s": {
"main": [
[
{
"node": "Fetch Latest Videos",
"type": "main",
"index": 0
}
]
]
},
"YT Tags": {
"main": [
[
{
"node": "Update Video's Metadata",
"type": "main",
"index": 0
}
]
]
},
"YT Title": {
"main": [
[]
]
},
"gettitle": {
"main": [
[
{
"node": "Set Publish Date",
"type": "main",
"index": 0
}
]
]
},
"Every Day": {
"main": [
[
{
"node": "Get Videos to reschedule",
"type": "main",
"index": 0
}
]
]
},
"new video?": {
"main": [
[],
[
{
"node": "getLatestVideoID",
"type": "main",
"index": 0
}
]
]
},
"2.5FlashPrev": {
"ai_languageModel": [
[
{
"node": "YT Tags",
"type": "ai_languageModel",
"index": 0
}
]
]
},
"get video id": {
"main": [
[
{
"node": "Remove Duplicates from previous Runs",
"type": "main",
"index": 0
}
]
]
},
"Get Transcript": {
"main": [
[
{
"node": "Adjust Transcript Format",
"type": "main",
"index": 0
}
]
]
},
"Get Video Data": {
"main": [
[
{
"node": "Loop over Video IDs",
"type": "main",
"index": 0
}
]
]
},
"Loop Over Items": {
"main": [
[],
[
{
"node": "get video id",
"type": "main",
"index": 0
}
]
]
},
"Set Publish Date": {
"main": [
[
{
"node": "Loop over All Videos not Published",
"type": "main",
"index": 0
}
]
]
},
"getLatestVideoID": {
"main": [
[
{
"node": "Get Transcript",
"type": "main",
"index": 0
}
]
]
},
"Create Description": {
"main": [
[
{
"node": "YT Tags",
"type": "main",
"index": 0
},
{
"node": "YT Title",
"type": "main",
"index": 0
}
]
]
},
"Fetch Latest Videos": {
"main": [
[
{
"node": "Loop Over Items",
"type": "main",
"index": 0
}
]
]
},
"Loop over Video IDs": {
"main": [
[
{
"node": "Return Private Videos",
"type": "main",
"index": 0
}
],
[
{
"node": "Get Video Data",
"type": "main",
"index": 0
}
]
]
},
"Return Private Videos": {
"main": [
[
{
"node": "Loop over All Videos not Published",
"type": "main",
"index": 0
}
]
]
},
"Get video Ids seperated": {
"main": [
[
{
"node": "Loop over Video IDs",
"type": "main",
"index": 0
}
]
]
},
"Update Video's Metadata": {
"main": [
[
{
"node": "3s",
"type": "main",
"index": 0
}
]
]
},
"Adjust Transcript Format": {
"main": [
[
{
"node": "Create Description",
"type": "main",
"index": 0
}
]
]
},
"Get Videos to reschedule": {
"main": [
[
{
"node": "Get video Ids seperated",
"type": "main",
"index": 0
}
]
]
},
"When clicking ‘Test workflow’": {
"main": [
[
{
"node": "Get Videos to reschedule",
"type": "main",
"index": 0
}
]
]
},
"Loop over All Videos not Published": {
"main": [
[
{
"node": "4s",
"type": "main",
"index": 0
}
],
[
{
"node": "gettitle",
"type": "main",
"index": 0
}
]
]
},
"Remove Duplicates from previous Runs": {
"main": [
[
{
"node": "new video?",
"type": "main",
"index": 0
}
]
]
}
}
}常见问题
如何使用这个工作流?
复制上方的 JSON 配置代码,在您的 n8n 实例中创建新工作流并选择「从 JSON 导入」,粘贴配置后根据需要修改凭证设置即可。
这个工作流适合什么场景?
高级 - 人工智能, 营销
需要付费吗?
本工作流完全免费,您可以直接导入使用。但请注意,工作流中使用的第三方服务(如 OpenAI API)可能需要您自行付费。
相关工作流推荐
在可视化参考库中探索n8n节点
在可视化参考库中探索n8n节点
If
Ftp
Set
+93
113 节点I versus AI
其他
WordPress博客自动化专业版(深度研究)v1
WordPress自动博客专业版 - 含深度研究的内容自动化机器
If
Set
Xml
+24
77 节点Daniel Ng
人工智能
使用GPT-4o、WordPress和LinkedIn发布自动化RSS内容到博客文章
使用GPT-4o、WordPress和LinkedIn发布自动化RSS内容到博客文章
If
Set
Code
+21
40 节点Immanuel
人工智能
WordPress 内容生成器 v3
WordPress 内容生成器 v3
If
Set
Code
+21
102 节点Alex Kim
人工智能
使用AI、ElevenLabs和多平台发布创建和审批POV视频
使用AI、ElevenLabs和多平台发布创建和审批POV视频(TikTok/IG/YT)
If
Set
Code
+20
60 节点Immanuel
设计
YouTube RSS到Slack摘要
使用Google Sheets、RapidAPI和GPT-4o-mini将新YouTube视频摘要发送到Slack
If
Set
Xml
+13
40 节点Naveen Choudhary
人工智能