Automatisation Google Sheets avec n8n : collecte de données XML
- Ce workflow n8n a pour objectif d'automatiser la collecte et le traitement de données à partir de Google Sheets et d'API externes, en utilisant des fichiers XML. Dans un contexte où les entreprises doivent régulièrement analyser des données pour prendre des décisions éclairées, ce workflow permet de récupérer des mots-clés sauvegardés, d'interroger Google Trends et de traiter les résultats pour en extraire des informations pertinentes. Les cas d'usage incluent la veille concurrentielle, l'analyse de tendances de marché et l'optimisation de contenu.
- Le workflow commence par un déclencheur manuel, permettant à l'utilisateur de tester le flux à la demande. Ensuite, il utilise un nœud XML pour parser les données, suivi d'une requête HTTP vers Google Trends pour obtenir des informations sur les mots-clés. Les mots-clés sauvegardés sont récupérés depuis Google Sheets, et le flux est structuré pour traiter les données en lots, facilitant ainsi la gestion des informations. Les nœuds de condition permettent de vérifier si des URL ont été récupérées avant de les sauvegarder, garantissant ainsi la qualité des données.
- Les bénéfices business incluent une réduction significative du temps passé à collecter et analyser des données, une meilleure prise de décision grâce à des informations à jour et pertinentes, ainsi qu'une optimisation des ressources humaines. En intégrant ce workflow n8n, les entreprises peuvent améliorer leur efficacité opérationnelle et leur réactivité face aux évolutions du marché.
Workflow n8n Google Sheets, data scraping, veille concurrentielle : vue d'ensemble
Schéma des nœuds et connexions de ce workflow n8n, généré à partir du JSON n8n.
Workflow n8n Google Sheets, data scraping, veille concurrentielle : détail des nœuds
Inscris-toi pour voir l'intégralité du workflow
Inscription gratuite
S'inscrire gratuitementBesoin d'aide ?{
"id": "Eyh4jc7RK7rCTh4z",
"meta": {
"instanceId": "38fb1860cc6284b8af9ba3b485f32cc1851cd97470ef1b4a472b5e707f1c93b5",
"templateCredsSetupCompleted": true
},
"name": "My workflow 2",
"tags": [],
"nodes": [
{
"id": "084bcc9e-9d05-4b69-8cb1-eccdcb67358e",
"name": "When clicking ‘Test workflow’",
"type": "n8n-nodes-base.manualTrigger",
"position": [
500,
720
],
"parameters": {},
"typeVersion": 1
},
{
"id": "f593e3f1-adea-4ef7-9779-4f2436fe7774",
"name": "XML",
"type": "n8n-nodes-base.xml",
"position": [
1540,
880
],
"parameters": {
"options": {
"normalize": false,
"explicitArray": false
}
},
"executeOnce": true,
"typeVersion": 1
},
{
"id": "5906371f-d5da-4141-876f-542cb5d0d1a8",
"name": "GoogleTrends",
"type": "n8n-nodes-base.httpRequest",
"position": [
1280,
880
],
"parameters": {
"url": "https://trends.google.it/trending/rss?geo=IT",
"options": {}
},
"executeOnce": true,
"retryOnFail": true,
"typeVersion": 4.2
},
{
"id": "7badc1ad-48c2-4142-88bb-fa3f442abd66",
"name": "CONFIG",
"type": "n8n-nodes-base.set",
"position": [
760,
880
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "25d7e553-9678-40ad-bb69-e4eb4bce4d11",
"name": "min_traffic",
"type": "number",
"value": 500
},
{
"id": "decd0a3d-ddc5-45c3-a56f-ee1f14705019",
"name": "max_results",
"type": "number",
"value": 3
},
{
"id": "12cdd78a-45a7-499e-8fe5-0ab6a7da8a10",
"name": "jina_key",
"type": "string",
"value": ""
}
]
}
},
"typeVersion": 3.4
},
{
"id": "b92ad672-ea1d-4b5b-ae1d-0aa883c5db9a",
"name": "Get saved keywords",
"type": "n8n-nodes-base.googleSheets",
"position": [
1020,
880
],
"parameters": {
"options": {},
"sheetName": {
"__rl": true,
"mode": "list",
"value": "gid=0",
"cachedResultUrl": "",
"cachedResultName": ""
},
"documentId": {
"__rl": true,
"mode": "list",
"value": "",
"cachedResultUrl": "",
"cachedResultName": ""
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"id": "0HENZXUy9PlxLx0O",
"name": "Google Sheets account"
}
},
"executeOnce": true,
"typeVersion": 4.5,
"alwaysOutputData": false
},
{
"id": "e5639494-d757-442f-942f-75927ecadd86",
"name": "Loop Over Items",
"type": "n8n-nodes-base.splitInBatches",
"position": [
740,
1380
],
"parameters": {
"options": {}
},
"typeVersion": 3
},
{
"id": "2c81d605-6749-47a2-95ba-846d86388c04",
"name": "Mapping",
"type": "n8n-nodes-base.set",
"position": [
1000,
1380
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "7230decf-45d9-4006-b005-614fb1dede10",
"name": "summary",
"type": "string",
"value": "={{ $('content1').item.json.data.text.replaceAll('\\n', ' ').trim() }}\n---\n{{ $('content2').item.json.data.text.replaceAll('\\n', ' ').trim() }}\n---\n{{ $('content3').item.json.data.text.replaceAll('\\n', ' ').trim() }}"
},
{
"id": "ad8f7dcd-fc93-41f3-b643-db4a2b569119",
"name": "trending_keyword",
"type": "string",
"value": "={{ $('New keywords').item.json.trending_keyword }}"
},
{
"id": "a3838385-90e2-4308-b147-5ef6de4a2c19",
"name": "approx_traffic",
"type": "number",
"value": "={{ $('New keywords').item.json.approx_traffic }}"
},
{
"id": "fc8523d5-a68d-443b-ad49-9057dee85617",
"name": "pubDate",
"type": "string",
"value": "={{ $('New keywords').item.json.pubDate }}"
},
{
"id": "139fd57f-8ccc-453b-9f8f-94c9546bbd1c",
"name": "status",
"type": "string",
"value": "idea"
},
{
"id": "39fa6799-78db-453e-ad29-359ab441e912",
"name": "news_item_url1",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_url1 }}"
},
{
"id": "1e6e7545-526a-4003-ac92-520fa04cfe1d",
"name": "news_item_title1",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_title1 }}"
},
{
"id": "12c019fc-2fe6-41e8-a8b8-e38bdfa16215",
"name": "news_item_title2",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_title2 }}"
},
{
"id": "b14b5835-66b7-448c-b9a5-d9f85d9f7f12",
"name": "news_item_url2",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_url2 }}"
},
{
"id": "4df8d3e0-7c8d-40e1-8ed7-b1743a8bbf17",
"name": "news_item_title3",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_title3 }}"
},
{
"id": "7fe45e6d-1978-49b4-b289-c33e3d68f71a",
"name": "news_item_url3",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_url3 }}"
},
{
"id": "ef39509c-c4e7-49b1-9ee8-ad82a8af9514",
"name": "news_item_picture1",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_picture1 }}"
},
{
"id": "a2210ea6-8ee5-408a-9ba1-5e07bd4d7f1b",
"name": "news_item_source1",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_source1 }}"
},
{
"id": "b6136672-4c09-4da0-ba5b-d9026877ca1e",
"name": "news_item_picture2",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_picture2 }}"
},
{
"id": "f9a54dca-079c-4431-af34-6bb98a6d8711",
"name": "news_item_source2",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_source2 }}"
},
{
"id": "aa38fecd-3743-447f-aa54-a1a86b5ad717",
"name": "news_item_picture3",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_picture3 }}"
},
{
"id": "2ff53574-9f9d-4e35-afbe-161e77a58515",
"name": "news_item_source3",
"type": "string",
"value": "={{ $('New keywords').item.json.news_item_source3 }}"
}
]
}
},
"typeVersion": 3.4
},
{
"id": "5ca98d8f-0bc6-4b77-a367-81ed2509deba",
"name": "Google Sheets",
"type": "n8n-nodes-base.googleSheets",
"position": [
1580,
1180
],
"parameters": {
"columns": {
"value": {
"status": "idea",
"pubDate": "={{ $json.pubDate }}",
"abstract": "={{ $json.abstract.replaceAll(' ', '').substring(0, 49999) }}",
"approx_traffic": "={{ $json.approx_traffic }}",
"news_item_url1": "={{ $json.news_item_url1 }}",
"news_item_url2": "={{ $json.news_item_url2 }}",
"news_item_url3": "={{ $json.news_item_url3 }}",
"news_item_title1": "={{ $json.news_item_title1 }}",
"news_item_title2": "={{ $json.news_item_title2 }}",
"news_item_title3": "={{ $json.news_item_title3 }}",
"trending_keyword": "={{ $json.trending_keyword }}",
"news_item_source1": "={{ $json.news_item_source1 }}",
"news_item_source2": "={{ $json.news_item_source2 }}",
"news_item_source3": "={{ $json.news_item_source3 }}",
"news_item_picture1": "={{ $json.news_item_picture1 }}",
"news_item_picture2": "={{ $json.news_item_picture2 }}",
"news_item_picture3": "={{ $json.news_item_picture3 }}"
},
"schema": [
{
"id": "status",
"type": "string",
"display": true,
"required": false,
"displayName": "status",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "trending_keyword",
"type": "string",
"display": true,
"required": false,
"displayName": "trending_keyword",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "approx_traffic",
"type": "string",
"display": true,
"required": false,
"displayName": "approx_traffic",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "abstract",
"type": "string",
"display": true,
"required": false,
"displayName": "abstract",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "pubDate",
"type": "string",
"display": true,
"required": false,
"displayName": "pubDate",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_url1",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_url1",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_title1",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_title1",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_picture1",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_picture1",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_source1",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_source1",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_url2",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_url2",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_title2",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_title2",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_picture2",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_picture2",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_source2",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_source2",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_url3",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_url3",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_title3",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_title3",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_picture3",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_picture3",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "news_item_source3",
"type": "string",
"display": true,
"required": false,
"displayName": "news_item_source3",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "append",
"sheetName": {
"__rl": true,
"mode": "list",
"value": "gid=0",
"cachedResultUrl": "",
"cachedResultName": ""
},
"documentId": {
"__rl": true,
"mode": "list",
"value": "",
"cachedResultUrl": "",
"cachedResultName": ""
}
},
"typeVersion": 4.5
},
{
"id": "41fcb412-ea5d-4adc-8d40-d72398537150",
"name": "New keywords",
"type": "n8n-nodes-base.code",
"position": [
1780,
880
],
"parameters": {
"jsCode": "const max_results = $('CONFIG').first().json.max_results;\nconst min_traffic = $('CONFIG').first().json.min_traffic;\n\nconst gsheet = $(\"Get saved keywords\").all();\nconst gsheetKeys = gsheet.map(record => record.json.trending_keyword);\n\nconst items = $('XML').first().json.rss.channel.item;\nconst trafficKey = Object.keys(items[0]).find(key => key.includes(\"approx_traffic\"));\nconst parseTraffic = (traffic) => parseInt(traffic.replace('+', ''), 10);\n\nconst newItems = items.map(item => {\n const links = Array.isArray(item[\"ht:news_item\"]) ? item[\"ht:news_item\"].slice(0, 3) : [];\n\n const flattenedLinks = links.reduce((acc, news, index) => {\n acc[`news_item_url${index + 1}`] = news[\"ht:news_item_url\"];\n acc[`news_item_title${index + 1}`] = news[\"ht:news_item_title\"];\n acc[`news_item_picture${index + 1}`] = news[\"ht:news_item_picture\"];\n acc[`news_item_source${index + 1}`] = news[\"ht:news_item_source\"];\n return acc;\n }, {});\n\n return {\n trending_keyword: item.title,\n approx_traffic: parseTraffic(item[trafficKey]),\n pubDate: item.pubDate,\n ...flattenedLinks, // Aggiungi i link\n };\n}).filter(item => \n item.approx_traffic >= min_traffic && \n !gsheetKeys.includes(item.trending_keyword) // Filtra quelli già presenti in Google Sheets\n);\n\nlet sortedItems = newItems.sort((a, b) => b.approx_traffic - a.approx_traffic);\nif (max_results > 0) {\n sortedItems = sortedItems.slice(0, max_results);\n}\n\nreturn sortedItems;\n"
},
"typeVersion": 2,
"alwaysOutputData": false
},
{
"id": "56a953da-15a7-48da-a299-c53a7947c45e",
"name": "content1",
"type": "n8n-nodes-base.httpRequest",
"position": [
1020,
1700
],
"parameters": {
"url": "=https://r.jina.ai/{{ $('New keywords').item.json.news_item_url1 }}",
"options": {},
"sendHeaders": true,
"headerParameters": {
"parameters": [
{
"name": "Authorization",
"value": "=Bearer {{ $('CONFIG').item.json.jina_key }}"
},
{
"name": "Accept",
"value": "application/json"
},
{
"name": "X-Remove-Selector",
"value": "a, link, script, footer, img, svg"
},
{
"name": "X-Retain-Images",
"value": "none"
},
{
"name": "X-Return-Format",
"value": "text"
}
]
}
},
"typeVersion": 4.2
},
{
"id": "e3dbb73f-eac8-47aa-b621-0775dd09c5bf",
"name": "content2",
"type": "n8n-nodes-base.httpRequest",
"position": [
1280,
1700
],
"parameters": {
"url": "=https://r.jina.ai/{{ $('New keywords').item.json.news_item_url2 }}",
"options": {},
"sendHeaders": true,
"headerParameters": {
"parameters": [
{
"name": "Authorization",
"value": "=Bearer {{ $('CONFIG').item.json.jina_key }}"
},
{
"name": "Accept",
"value": "application/json"
},
{
"name": "X-Remove-Selector",
"value": "a, link, script, footer, img, svg"
},
{
"name": "X-Retain-Images",
"value": "none"
},
{
"name": "X-Return-Format",
"value": "text"
}
]
}
},
"typeVersion": 4.2
},
{
"id": "0723267a-5e4e-40e2-87bf-4c215c79b66c",
"name": "content3",
"type": "n8n-nodes-base.httpRequest",
"position": [
1560,
1700
],
"parameters": {
"url": "=https://r.jina.ai/{{ $('New keywords').item.json.news_item_url3 }}",
"options": {},
"sendHeaders": true,
"headerParameters": {
"parameters": [
{
"name": "Authorization",
"value": "=Bearer {{ $('CONFIG').item.json.jina_key }}"
},
{
"name": "Accept",
"value": "application/json"
},
{
"name": "X-Remove-Selector",
"value": "a, link, script, footer, img, svg"
},
{
"name": "X-Retain-Images",
"value": "none"
},
{
"name": "X-Return-Format",
"value": "text"
}
]
}
},
"typeVersion": 4.2
},
{
"id": "8621b782-a182-479a-afa1-de0b525d3909",
"name": "Start every hour past 11 minutes",
"type": "n8n-nodes-base.scheduleTrigger",
"position": [
500,
880
],
"parameters": {
"rule": {
"interval": [
{
"field": "cronExpression",
"expression": "11 */1 * * *"
}
]
}
},
"typeVersion": 1.2
},
{
"id": "d04e89cd-a578-45d9-88f2-be4c72407049",
"name": "Sticky Note",
"type": "n8n-nodes-base.stickyNote",
"position": [
420,
560
],
"parameters": {
"color": 5,
"height": 1300,
"content": "## Cron trigger\nGoogle Trends update the RSS feed every 10 minutes. This will start wordflow 1 minute after. "
},
"typeVersion": 1
},
{
"id": "4644b6ca-43da-42ab-870c-eeb52610208c",
"name": "Sticky Note1",
"type": "n8n-nodes-base.stickyNote",
"position": [
680,
560
],
"parameters": {
"color": 3,
"height": 480,
"content": "## CONFIGURATION\nmin_traffic is a numeric value. Google Trend RSS has an approx traffic value 100, 200, 500, 1000 etc.\n\nmax_result is a numeric value used to limit max rss to scrape\n\njina_key is the jina.ai API key"
},
"typeVersion": 1
},
{
"id": "b4ac3f6a-dc72-4e3e-9fa1-80298a66ddf9",
"name": "Sticky Note2",
"type": "n8n-nodes-base.stickyNote",
"position": [
940,
560
],
"parameters": {
"height": 480,
"content": "## Google Sheet Database\nThis is main sheet where all your Editorial plan will be saved.\n\nThe column status value could be a trigger for other automations"
},
"typeVersion": 1
},
{
"id": "09fa9ed7-2557-46ae-857f-e251bf25b10e",
"name": "Sticky Note3",
"type": "n8n-nodes-base.stickyNote",
"position": [
1200,
560
],
"parameters": {
"height": 480,
"content": "## Google Trends request\n\nWe get last kwyword in trend. Every item has a main keyword and 3 URL. We will use those url to scrape content and generate a combined summary"
},
"typeVersion": 1
},
{
"id": "6d3d6f90-4eae-4239-b8cd-bfdb40bf01e9",
"name": "Sticky Note4",
"type": "n8n-nodes-base.stickyNote",
"position": [
1460,
560
],
"parameters": {
"height": 480,
"content": "## Simple conversion\n\nConverts XML RSS into a more readable json object"
},
"typeVersion": 1
},
{
"id": "3b5dd19f-ac2d-426b-8853-1af3819e10f6",
"name": "Sticky Note5",
"type": "n8n-nodes-base.stickyNote",
"position": [
1720,
560
],
"parameters": {
"height": 480,
"content": "## Building dataset\n\nHere we limits results, filter by mmin traffic and we flat the RSS structure to adapt to Google Sheet, fields are renamed as per description.\n\nThen RSS result and Google Sheet is compared, if a new keyword is found we have result. If RSS give a keyword already srtored, this node doesn't give any output."
},
"typeVersion": 1
},
{
"id": "cce50db5-6566-439c-9b90-3f8720411613",
"name": "Sticky Note6",
"type": "n8n-nodes-base.stickyNote",
"position": [
940,
1080
],
"parameters": {
"height": 460,
"content": "## Data mapping\n\nHere you have all fields needed in Google Sheet.\n\nWhile done, the content of 3 website linked in Google Trends RSS will be merged in a single Summary field"
},
"typeVersion": 1
},
{
"id": "d57a8c16-21c6-4388-bb91-093428061ac5",
"name": "Sticky Note7",
"type": "n8n-nodes-base.stickyNote",
"position": [
1200,
1080
],
"parameters": {
"color": 3,
"height": 460,
"content": "## Data check\n\nSometimes scraping HTML content fails (for some reasons), that's normal but this should avoid to save a zero content if all 3 scraping nodes will fail"
},
"typeVersion": 1
},
{
"id": "2bcbf0a9-423d-45eb-a444-ab2140db2db6",
"name": "Sticky Note8",
"type": "n8n-nodes-base.stickyNote",
"position": [
680,
1080
],
"parameters": {
"height": 460,
"content": "## Data mapping\n\nHere you have all fields needed in Google Sheet.\n\nWhile done, the content of 3 website linked in Google Trends RSS will be merged in a single Summary field"
},
"typeVersion": 1
},
{
"id": "692b342c-c252-48c6-ad11-b58906aa62e2",
"name": "If we have scraped min 1 url -> Save",
"type": "n8n-nodes-base.if",
"position": [
1280,
1380
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "42b15ebc-f2f7-4dc0-957f-b04d1bdacb41",
"operator": {
"type": "boolean",
"operation": "true",
"singleValue": true
},
"leftValue": "={{ $json.summary.length > 100 }}",
"rightValue": ""
}
]
}
},
"typeVersion": 2.2
},
{
"id": "f2f94f0b-dcb4-4b52-86f8-c92aa2fc3d88",
"name": "All scraping node failed. Don't save record without summary",
"type": "n8n-nodes-base.noOp",
"position": [
1580,
1380
],
"parameters": {},
"typeVersion": 1
},
{
"id": "d3f42eb0-5e37-40ff-a476-46b6384f2647",
"name": "Sticky Note9",
"type": "n8n-nodes-base.stickyNote",
"position": [
680,
1560
],
"parameters": {
"color": 7,
"width": 1280,
"height": 300,
"content": "## Scraping\n\nHere jina.ai will get text content from 3 Google Trends URLs"
},
"typeVersion": 1
},
{
"id": "8178a70e-f3d2-4157-8f4b-9adaf8932e8e",
"name": "Sticky Note10",
"type": "n8n-nodes-base.stickyNote",
"position": [
1460,
1080
],
"parameters": {
"color": 4,
"width": 500,
"height": 460,
"content": "## Saving output\n\n"
},
"typeVersion": 1
}
],
"active": false,
"pinData": {},
"settings": {
"executionOrder": "v1"
},
"versionId": "81aec91d-f995-4a14-b801-ef44070e7153",
"connections": {
"XML": {
"main": [
[
{
"node": "New keywords",
"type": "main",
"index": 0
}
]
]
},
"CONFIG": {
"main": [
[
{
"node": "Get saved keywords",
"type": "main",
"index": 0
}
]
]
},
"Mapping": {
"main": [
[
{
"node": "If we have scraped min 1 url -> Save",
"type": "main",
"index": 0
}
]
]
},
"content1": {
"main": [
[
{
"node": "content2",
"type": "main",
"index": 0
}
]
]
},
"content2": {
"main": [
[
{
"node": "content3",
"type": "main",
"index": 0
}
]
]
},
"content3": {
"main": [
[
{
"node": "Loop Over Items",
"type": "main",
"index": 0
}
]
]
},
"GoogleTrends": {
"main": [
[
{
"node": "XML",
"type": "main",
"index": 0
}
]
]
},
"New keywords": {
"main": [
[
{
"node": "Loop Over Items",
"type": "main",
"index": 0
}
]
]
},
"Loop Over Items": {
"main": [
[
{
"node": "Mapping",
"type": "main",
"index": 0
}
],
[
{
"node": "content1",
"type": "main",
"index": 0
}
]
]
},
"Get saved keywords": {
"main": [
[
{
"node": "GoogleTrends",
"type": "main",
"index": 0
}
]
]
},
"Start every hour past 11 minutes": {
"main": [
[
{
"node": "CONFIG",
"type": "main",
"index": 0
}
]
]
},
"When clicking ‘Test workflow’": {
"main": [
[
{
"node": "CONFIG",
"type": "main",
"index": 0
}
]
]
},
"If we have scraped min 1 url -> Save": {
"main": [
[
{
"node": "Google Sheets",
"type": "main",
"index": 0
}
],
[
{
"node": "All scraping node failed. Don't save record without summary",
"type": "main",
"index": 0
}
]
]
}
}
}Workflow n8n Google Sheets, data scraping, veille concurrentielle : pour qui est ce workflow ?
Ce workflow s'adresse aux équipes marketing, aux analystes de données et aux responsables de la veille concurrentielle au sein des PME et des grandes entreprises. Un niveau technique intermédiaire est recommandé pour la personnalisation et l'optimisation du flux.
Workflow n8n Google Sheets, data scraping, veille concurrentielle : problème résolu
Ce workflow résout le problème de la collecte manuelle de données, souvent chronophage et sujette à erreurs. En automatisant le processus de récupération et d'analyse des mots-clés, il élimine les frustrations liées à la gestion des données dispersées et réduit les risques d'inexactitudes. Après mise en place, les utilisateurs bénéficient d'une vision claire et actualisée des tendances de marché, leur permettant de réagir rapidement aux changements.
Workflow n8n Google Sheets, data scraping, veille concurrentielle : étapes du workflow
Étape 1 : Le flux est déclenché manuellement par l'utilisateur.
- Étape 1 : Les données XML sont traitées pour en extraire les informations nécessaires.
- Étape 2 : Une requête HTTP est envoyée à Google Trends pour obtenir des données sur les mots-clés.
- Étape 3 : Les mots-clés sauvegardés sont récupérés depuis Google Sheets.
- Étape 4 : Les données sont traitées en lots pour une gestion efficace.
- Étape 5 : Une condition vérifie si au moins une URL a été récupérée avant de procéder à la sauvegarde des résultats.
Workflow n8n Google Sheets, data scraping, veille concurrentielle : guide de personnalisation
Pour personnaliser ce workflow, commencez par modifier l'URL de la requête HTTP pour Google Trends selon vos besoins. Vous pouvez également adapter le nom de la feuille Google Sheets pour correspondre à votre document. Pensez à ajuster les paramètres des nœuds de condition pour affiner les critères de sauvegarde des données. Si nécessaire, intégrez d'autres API ou services pour enrichir le flux. Assurez-vous de sécuriser les données en utilisant des méthodes d'authentification appropriées pour les API.