Erstelle Videos mit Google Veo3 und lade sie auf YouTube hoch
Dies ist ein AI, Marketing-Bereich Automatisierungsworkflow mit 22 Nodes. Hauptsächlich werden If, Set, Wait, GoogleDrive, HttpRequest und andere Nodes verwendet, kombiniert mit KI-Technologie für intelligente Automatisierung. AI-Videos mit Google Veo3 generieren, in Google Drive speichern und auf YouTube hochladen
- •Google Drive API-Anmeldedaten
- •Möglicherweise sind Ziel-API-Anmeldedaten erforderlich
- •Google Sheets API-Anmeldedaten
- •OpenAI API Key
Verwendete Nodes (22)
Kategorie
{
"id": "g1hmK8jw38TOYX7D",
"meta": {
"instanceId": "a4bfc93e975ca233ac45ed7c9227d84cf5a2329310525917adaf3312e10d5462",
"templateCredsSetupCompleted": true
},
"name": "Create Video with Google Veo3 and Upload to Youtube",
"tags": [],
"nodes": [
{
"id": "f1fcb9ab-37aa-44a3-91fc-8480351aa5cd",
"name": "Bei Klick auf 'Test-Workflow'",
"type": "n8n-nodes-base.manualTrigger",
"position": [
-220,
840
],
"parameters": {},
"typeVersion": 1
},
{
"id": "58194812-a64d-401e-be5e-2f1ba9210557",
"name": "Status abrufen",
"type": "n8n-nodes-base.httpRequest",
"position": [
840,
840
],
"parameters": {
"url": "=https://queue.fal.run/fal-ai/veo3/requests/{{ $('Create Video').item.json.request_id }}/status ",
"options": {},
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"id": "daOZafXpRXLtoLUV",
"name": "Fal.run API"
}
},
"typeVersion": 4.2
},
{
"id": "1e23339c-f829-4426-b4f6-b02add8f8c5e",
"name": "60 Sek. warten",
"type": "n8n-nodes-base.wait",
"position": [
660,
840
],
"webhookId": "490facb8-d0ae-402e-ab59-a87720cf0bdd",
"parameters": {
"amount": 60
},
"typeVersion": 1.1
},
{
"id": "98ad8a6d-9ded-4f4e-a4ef-b624f7fe7e39",
"name": "Zeitplan-Trigger",
"type": "n8n-nodes-base.scheduleTrigger",
"position": [
-220,
700
],
"parameters": {
"rule": {
"interval": [
{
"field": "minutes"
}
]
}
},
"typeVersion": 1.2
},
{
"id": "262608c6-e905-4d16-bc52-22b67c1bc298",
"name": "Notizzettel3",
"type": "n8n-nodes-base.stickyNote",
"position": [
-220,
-460
],
"parameters": {
"color": 3,
"width": 740,
"height": 280,
"content": "# Generate AI Videos with Google Veo3, Save to Google Drive and Upload to YouTube\n\nThis workflow allows users to **generate AI videos** using **Google Veo3**, save them to **Google Drive**, generate optimized YouTube titles with GPT-4o, and **automatically upload them to YouTube** . The entire process is triggered from a Google Sheet that acts as the central interface for input and output.\n\nIT automates video creation, uploading, and tracking, ensuring seamless integration between Google Sheets, Google Drive, Google Veo3, and YouTube.\n\n\n\n\n"
},
"typeVersion": 1
},
{
"id": "1ea1879e-1e8e-42f9-8b11-7f771cfca2f8",
"name": "Notizzettel4",
"type": "n8n-nodes-base.stickyNote",
"position": [
-220,
-140
],
"parameters": {
"width": 740,
"height": 200,
"content": "## STEP 1 - GOOGLE SHEET\nCreate a [Google Sheet like this](https://docs.google.com/spreadsheets/d/1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ/edit?usp=sharing).\n\nPlease insert:\n- in the \"PROMPT\" column the accurate description of the video you want to create\n- in the \"DURATION\" column the lenght of the video you want to create\n\nLeave the \"VIDEO\" column unfilled. It will be inserted by the system once the video has been created"
},
"typeVersion": 1
},
{
"id": "8c54b723-d0b9-4d89-8150-975306640a96",
"name": "Abgeschlossen?",
"type": "n8n-nodes-base.if",
"position": [
1020,
840
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "383d112e-2cc6-4dd4-8985-f09ce0bd1781",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.status }}",
"rightValue": "COMPLETED"
}
]
}
},
"typeVersion": 2.2
},
{
"id": "1135e1f0-b605-4724-a8b3-7f16b9887ef7",
"name": "Ergebnis aktualisieren",
"type": "n8n-nodes-base.googleSheets",
"position": [
860,
1100
],
"parameters": {
"columns": {
"value": {
"VIDEO": "={{ $('Get Url Video').item.json.video.url }}",
"row_number": "={{ $('Get new video').item.json.row_number }}"
},
"schema": [
{
"id": "PROMPT",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "PROMPT",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "DURATION",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "DURATION",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "VIDEO",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "VIDEO",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "YOUTUBE_URL",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "YOUTUBE_URL",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "row_number",
"type": "string",
"display": true,
"removed": false,
"readOnly": true,
"required": false,
"displayName": "row_number",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"row_number"
],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "update",
"sheetName": {
"__rl": true,
"mode": "list",
"value": "gid=0",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/11ebWJvwwXHgvQld9kxywKQUvIoBw6xMa0g0BuIqHDxE/edit#gid=0",
"cachedResultName": "Foglio1"
},
"documentId": {
"__rl": true,
"mode": "list",
"value": "1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ/edit?usp=drivesdk",
"cachedResultName": "Video Google Veo3"
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"id": "JYR6a64Qecd6t8Hb",
"name": "Google Sheets account"
}
},
"typeVersion": 4.5
},
{
"id": "8d0ac30d-5a92-487b-aaff-f761bd720293",
"name": "Daten setzen",
"type": "n8n-nodes-base.set",
"position": [
220,
840
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "c713d31f-9abd-496a-ac79-e8e2efe60aa0",
"name": "prompt",
"type": "string",
"value": "={{ $json.PROMPT }}\n\nDuration of the video: {{ $json.DURATION }}"
}
]
}
},
"typeVersion": 3.4
},
{
"id": "ae68690d-c154-4ec9-a5b8-ba95137d2cf4",
"name": "Notizzettel5",
"type": "n8n-nodes-base.stickyNote",
"position": [
-220,
520
],
"parameters": {
"width": 740,
"height": 100,
"content": "## STEP 4 - MAIN FLOW\nStart the workflow manually or periodically by hooking the \"Schedule Trigger\" node. It is recommended to set it at 5 minute intervals."
},
"typeVersion": 1
},
{
"id": "429ab164-e165-409c-adc7-8a80c25b9f7d",
"name": "Notizzettel6",
"type": "n8n-nodes-base.stickyNote",
"position": [
-220,
100
],
"parameters": {
"width": 740,
"height": 140,
"content": "## STEP 2 - GET API KEY (YOURAPIKEY)\nCreate an account [here](https://fal.ai/) and obtain API KEY.\nIn the node \"Create Image\" set \"Header Auth\" and set:\n- Name: \"Authorization\"\n- Value: \"Key YOURAPIKEY\""
},
"typeVersion": 1
},
{
"id": "868339d3-e3f0-473b-9f1f-c7c4fe9c9898",
"name": "Notizzettel7",
"type": "n8n-nodes-base.stickyNote",
"position": [
400,
780
],
"parameters": {
"width": 180,
"height": 200,
"content": "Set API Key created in Step 2"
},
"typeVersion": 1
},
{
"id": "44793285-6bb8-471a-a632-e0fe33d2d047",
"name": "Neues Video abrufen",
"type": "n8n-nodes-base.googleSheets",
"position": [
0,
840
],
"parameters": {
"options": {},
"filtersUI": {
"values": [
{
"lookupColumn": "VIDEO"
}
]
},
"sheetName": {
"__rl": true,
"mode": "list",
"value": "gid=0",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ/edit#gid=0",
"cachedResultName": "Foglio1"
},
"documentId": {
"__rl": true,
"mode": "list",
"value": "1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ/edit?usp=drivesdk",
"cachedResultName": "Video Google Veo3"
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"id": "JYR6a64Qecd6t8Hb",
"name": "Google Sheets account"
}
},
"typeVersion": 4.5
},
{
"id": "7271ea9a-c4f5-4091-8f0f-ef40bb1d94af",
"name": "Video erstellen",
"type": "n8n-nodes-base.httpRequest",
"position": [
440,
840
],
"parameters": {
"url": "https://queue.fal.run/fal-ai/veo3",
"method": "POST",
"options": {},
"jsonBody": "={\n \"prompt\": \"{{$json.prompt}}\"\n}",
"sendBody": true,
"sendHeaders": true,
"specifyBody": "json",
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth",
"headerParameters": {
"parameters": [
{
"name": "Content-Type",
"value": "application/json"
}
]
}
},
"credentials": {
"httpHeaderAuth": {
"id": "daOZafXpRXLtoLUV",
"name": "Fal.run API"
}
},
"typeVersion": 4.2
},
{
"id": "f0cbd048-011e-47ee-8840-af630adf6f85",
"name": "Video-URL abrufen",
"type": "n8n-nodes-base.httpRequest",
"position": [
-220,
1220
],
"parameters": {
"url": "=https://queue.fal.run/fal-ai/veo3/requests/{{ $json.request_id }}",
"options": {},
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"id": "daOZafXpRXLtoLUV",
"name": "Fal.run API"
}
},
"typeVersion": 4.2
},
{
"id": "f48cef5b-0609-417b-b4ec-21614397cb07",
"name": "Video-Datei abrufen",
"type": "n8n-nodes-base.httpRequest",
"position": [
400,
1220
],
"parameters": {
"url": "={{ $('Get Url Video').item.json.video.url }}",
"options": {}
},
"typeVersion": 4.2
},
{
"id": "2cde22e1-1b71-4672-80dc-4992c4bdfe5d",
"name": "Video hochladen",
"type": "n8n-nodes-base.googleDrive",
"position": [
680,
1100
],
"parameters": {
"name": "={{ $now.format('yyyyLLddHHmmss') }}-{{ $('Get Url Video').item.json.video.file_name }}",
"driveId": {
"__rl": true,
"mode": "list",
"value": "My Drive"
},
"options": {},
"folderId": {
"__rl": true,
"mode": "list",
"value": "1aHRwLWyrqfzoVC8HoB-YMrBvQ4tLC-NZ",
"cachedResultUrl": "https://drive.google.com/drive/folders/1aHRwLWyrqfzoVC8HoB-YMrBvQ4tLC-NZ",
"cachedResultName": "Fal.run"
}
},
"credentials": {
"googleDriveOAuth2Api": {
"id": "HEy5EuZkgPZVEa9w",
"name": "Google Drive account (n3w.it)"
}
},
"typeVersion": 3
},
{
"id": "bf77f692-8a47-4f49-883b-ba045cb39f3b",
"name": "HTTP-Anfrage",
"type": "n8n-nodes-base.httpRequest",
"position": [
680,
1320
],
"parameters": {
"url": "https://api.upload-post.com/api/upload",
"method": "POST",
"options": {},
"sendBody": true,
"contentType": "multipart-form-data",
"authentication": "genericCredentialType",
"bodyParameters": {
"parameters": [
{
"name": "title",
"value": "={{ $('Generate title').item.json.message.content }}"
},
{
"name": "user",
"value": "YOUR_USERNAME"
},
{
"name": "platform[]",
"value": "youtube"
},
{
"name": "video",
"parameterType": "formBinaryData",
"inputDataFieldName": "data"
}
]
},
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"id": "DEE2XGvhGodgbAJh",
"name": "Upload-post.com API"
}
},
"typeVersion": 4.2
},
{
"id": "0fab9370-c079-40c8-9e87-e9b319e0bee7",
"name": "Titel generieren",
"type": "@n8n/n8n-nodes-langchain.openAi",
"position": [
20,
1220
],
"parameters": {
"modelId": {
"__rl": true,
"mode": "list",
"value": "gpt-4o-mini",
"cachedResultName": "GPT-4O-MINI"
},
"options": {},
"messages": {
"values": [
{
"content": "=Input: {{ $('Get new video').item.json.PROMPT }}"
},
{
"role": "system",
"content": "You are a YouTube SEO expert specialized in creating engaging and optimized titles.\n\nYour task is to generate an effective title for a YouTube video based on the user's video description.\n\nGUIDELINES:\n- Maximum 60 characters to avoid truncation\n- Use relevant keywords for SEO\n- Make the title catchy and clickable\n- Avoid excessive or misleading clickbait\n- Consider the target audience of the content\n- Use numbers, questions, or power words when appropriate\n- IMPORTANT: Generate the title in the same language as the input description\n\nOUTPUT FORMAT:\nProvide only the title, without additional explanations.\n\nEXAMPLE:\nInput: \"Tutorial video on how to cook perfect pasta carbonara\"\nOutput: \"PERFECT Carbonara in 10 Minutes - Chef's Secrets\""
}
]
}
},
"credentials": {
"openAiApi": {
"id": "TefveNaDaMERl1hY",
"name": "OpenAi account (Eure)"
}
},
"typeVersion": 1.8
},
{
"id": "cf9a58f0-0523-4229-ac2e-42f0f71d5306",
"name": "Youtube URL aktualisieren",
"type": "n8n-nodes-base.googleSheets",
"position": [
860,
1320
],
"parameters": {
"columns": {
"value": {
"VIDEO": "=",
"row_number": "={{ $('Get new video').item.json.row_number }}",
"YOUTUBE_URL": "https://youtu.be/{{ $json.results.youtube.video_id }}"
},
"schema": [
{
"id": "PROMPT",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "PROMPT",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "DURATION",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "DURATION",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "VIDEO",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "VIDEO",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "YOUTUBE_URL",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "YOUTUBE_URL",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "row_number",
"type": "string",
"display": true,
"removed": false,
"readOnly": true,
"required": false,
"displayName": "row_number",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"row_number"
],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "update",
"sheetName": {
"__rl": true,
"mode": "list",
"value": "gid=0",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/11ebWJvwwXHgvQld9kxywKQUvIoBw6xMa0g0BuIqHDxE/edit#gid=0",
"cachedResultName": "Foglio1"
},
"documentId": {
"__rl": true,
"mode": "list",
"value": "1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ",
"cachedResultUrl": "https://docs.google.com/spreadsheets/d/1pcoY9N_vQp44NtSRR5eskkL5Qd0N0BGq7Jh_4m-7VEQ/edit?usp=drivesdk",
"cachedResultName": "Video Google Veo3"
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"id": "JYR6a64Qecd6t8Hb",
"name": "Google Sheets account"
}
},
"typeVersion": 4.5
},
{
"id": "2f97346c-78df-41fe-b15d-c2af7e9ee680",
"name": "Notizzettel",
"type": "n8n-nodes-base.stickyNote",
"position": [
660,
1260
],
"parameters": {
"width": 180,
"height": 200,
"content": "Set YOUR_USERNAME in Step 3"
},
"typeVersion": 1
},
{
"id": "0d6517cb-d2a3-4afe-b163-25311faed711",
"name": "Notizzettel8",
"type": "n8n-nodes-base.stickyNote",
"position": [
-220,
280
],
"parameters": {
"width": 740,
"height": 200,
"content": "## STEP 3 - Upload video on Youtube\n- Find your API key in your [Upload-Post Manage Api Keys](https://app.upload-post.com/) 10 FREE uploads per month\n- Set the the \"Auth Header\":\n-- Name: Authorization\n-- Value: Apikey YOUR_API_KEY_HERE\n- Create profiles to manage your social media accounts. The \"Profile\" you choose will be used in the field YOUR_USRNAME (eg. test1 or test2). "
},
"typeVersion": 1
}
],
"active": false,
"pinData": {},
"settings": {
"executionOrder": "v1"
},
"versionId": "a358d31a-ae0a-44e0-83e4-0a0df359e143",
"connections": {
"8d0ac30d-5a92-487b-aaff-f761bd720293": {
"main": [
[
{
"node": "7271ea9a-c4f5-4091-8f0f-ef40bb1d94af",
"type": "main",
"index": 0
}
]
]
},
"8c54b723-d0b9-4d89-8150-975306640a96": {
"main": [
[
{
"node": "f0cbd048-011e-47ee-8840-af630adf6f85",
"type": "main",
"index": 0
}
],
[
{
"node": "1e23339c-f829-4426-b4f6-b02add8f8c5e",
"type": "main",
"index": 0
}
]
]
},
"58194812-a64d-401e-be5e-2f1ba9210557": {
"main": [
[
{
"node": "8c54b723-d0b9-4d89-8150-975306640a96",
"type": "main",
"index": 0
}
]
]
},
"7271ea9a-c4f5-4091-8f0f-ef40bb1d94af": {
"main": [
[
{
"node": "1e23339c-f829-4426-b4f6-b02add8f8c5e",
"type": "main",
"index": 0
}
]
]
},
"HTTP Request": {
"main": [
[
{
"node": "cf9a58f0-0523-4229-ac2e-42f0f71d5306",
"type": "main",
"index": 0
}
]
]
},
"2cde22e1-1b71-4672-80dc-4992c4bdfe5d": {
"main": [
[
{
"node": "1135e1f0-b605-4724-a8b3-7f16b9887ef7",
"type": "main",
"index": 0
}
]
]
},
"1e23339c-f829-4426-b4f6-b02add8f8c5e": {
"main": [
[
{
"node": "58194812-a64d-401e-be5e-2f1ba9210557",
"type": "main",
"index": 0
}
]
]
},
"f0cbd048-011e-47ee-8840-af630adf6f85": {
"main": [
[
{
"node": "0fab9370-c079-40c8-9e87-e9b319e0bee7",
"type": "main",
"index": 0
}
]
]
},
"44793285-6bb8-471a-a632-e0fe33d2d047": {
"main": [
[
{
"node": "8d0ac30d-5a92-487b-aaff-f761bd720293",
"type": "main",
"index": 0
}
]
]
},
"1135e1f0-b605-4724-a8b3-7f16b9887ef7": {
"main": [
[]
]
},
"0fab9370-c079-40c8-9e87-e9b319e0bee7": {
"main": [
[
{
"node": "f48cef5b-0609-417b-b4ec-21614397cb07",
"type": "main",
"index": 0
}
]
]
},
"f48cef5b-0609-417b-b4ec-21614397cb07": {
"main": [
[
{
"node": "2cde22e1-1b71-4672-80dc-4992c4bdfe5d",
"type": "main",
"index": 0
},
{
"node": "HTTP Request",
"type": "main",
"index": 0
}
]
]
},
"f1fcb9ab-37aa-44a3-91fc-8480351aa5cd": {
"main": [
[
{
"node": "44793285-6bb8-471a-a632-e0fe33d2d047",
"type": "main",
"index": 0
}
]
]
}
}
}Wie verwende ich diesen Workflow?
Kopieren Sie den obigen JSON-Code, erstellen Sie einen neuen Workflow in Ihrer n8n-Instanz und wählen Sie "Aus JSON importieren". Fügen Sie die Konfiguration ein und passen Sie die Anmeldedaten nach Bedarf an.
Für welche Szenarien ist dieser Workflow geeignet?
Experte - Künstliche Intelligenz, Marketing
Ist es kostenpflichtig?
Dieser Workflow ist völlig kostenlos. Beachten Sie jedoch, dass Drittanbieterdienste (wie OpenAI API), die im Workflow verwendet werden, möglicherweise kostenpflichtig sind.
Verwandte Workflows
Davide
@n3witaliaFull-stack Web Developer based in Italy specialising in Marketing & AI-powered automations. For business enquiries, send me an email at info@n3w.it or add me on Linkedin.com/in/davideboizza
Diesen Workflow teilen