This workflow corresponds to n8n.io template #2267 — we link there as the canonical source.
This workflow follows the Airtable → HTTP Request recipe pattern — see all workflows that pair these two integrations.
The workflow JSON
Copy or download the full n8n JSON below. Paste it into a new n8n workflow, add your credentials, activate. Full import guide →
{
"nodes": [
{
"id": "b9962fd6-af11-4a3a-935c-c168ac85eaa1",
"name": "When clicking \"Test workflow\"",
"type": "n8n-nodes-base.manualTrigger",
"position": [
80,
300
],
"parameters": {},
"typeVersion": 1
},
{
"id": "2ba3fe3a-e4c5-4014-8cb2-80716f18b222",
"name": "Get records",
"type": "n8n-nodes-base.airtable",
"position": [
300,
300
],
"parameters": {
"base": {
"__rl": true,
"mode": "list",
"value": "appkkDhXu7vZCFspD",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD",
"cachedResultName": "n8n test"
},
"limit": 10,
"table": {
"__rl": true,
"mode": "list",
"value": "tblMdmUiSTBrvrLq3",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD/tblMdmUiSTBrvrLq3",
"cachedResultName": "SEO meta title & desc"
},
"options": {},
"operation": "search",
"returnAll": false,
"filterByFormula": "=AND(url != \"\", {title tag} = \"\", {meta desc} = \"\")"
},
"credentials": {
"airtableTokenApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "0f26bb3c-f2cc-476b-b1af-3d4cd98463ce",
"name": "Get url content",
"type": "n8n-nodes-base.httpRequest",
"position": [
500,
300
],
"parameters": {
"url": "={{ $json.url }}",
"options": {}
},
"typeVersion": 4.2
},
{
"id": "3c67c390-5144-44cb-8618-d7e7e6c6cae5",
"name": "Extract title tag and meta description",
"type": "n8n-nodes-base.html",
"position": [
700,
300
],
"parameters": {
"options": {},
"operation": "extractHtmlContent",
"extractionValues": {
"values": [
{
"key": "titleTag",
"cssSelector": "title"
},
{
"key": "metaDesc",
"attribute": "content",
"cssSelector": "meta[name=\"description\"]",
"returnValue": "attribute"
}
]
}
},
"typeVersion": 1.2
},
{
"id": "7028b7af-0959-4ed5-bc54-fceb2e224976",
"name": "Update original record",
"type": "n8n-nodes-base.airtable",
"position": [
940,
300
],
"parameters": {
"base": {
"__rl": true,
"mode": "list",
"value": "appkkDhXu7vZCFspD",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD",
"cachedResultName": "n8n test"
},
"table": {
"__rl": true,
"mode": "list",
"value": "tblMdmUiSTBrvrLq3",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD/tblMdmUiSTBrvrLq3",
"cachedResultName": "SEO meta title & desc"
},
"columns": {
"value": {
"id": "={{ $('Get records').item.json.id }}",
"meta desc": "={{ $json.metaDesc }}",
"title tag": "={{ $json.titleTag }}"
},
"schema": [
{
"id": "id",
"type": "string",
"display": true,
"removed": false,
"readOnly": true,
"required": false,
"displayName": "id",
"defaultMatch": true
},
{
"id": "url",
"type": "string",
"display": true,
"removed": false,
"readOnly": false,
"required": false,
"displayName": "url",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "title tag",
"type": "string",
"display": true,
"removed": false,
"readOnly": false,
"required": false,
"displayName": "title tag",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "meta desc",
"type": "string",
"display": true,
"removed": false,
"readOnly": false,
"required": false,
"displayName": "meta desc",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "Created",
"type": "string",
"display": true,
"removed": true,
"readOnly": true,
"required": false,
"displayName": "Created",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "Calculation",
"type": "string",
"display": true,
"removed": true,
"readOnly": true,
"required": false,
"displayName": "Calculation",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"id"
]
},
"options": {},
"operation": "update"
},
"credentials": {
"airtableTokenApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "5b518969-553e-462f-ad4f-eb07e9b17eef",
"name": "Sticky Note",
"type": "n8n-nodes-base.stickyNote",
"position": [
140,
-60
],
"parameters": {
"width": 862.7929292929296,
"height": 316.6010101010099,
"content": "## How to use the workflow\n1. Set a Base in Airtable with a table with the following structure:\n `url`, `title tag`, `meta desc`\n2. Connect Airtable to the nodes and, with the following formula, get all the records that miss `title tag` and `meta desc`.\n3. Put a bunch of url in the table in the field `url` and let the workflow work.\n\n## Extra\n\n* You can also calculate the length for title tag and meta desc using formula field inside Airtable. This is the formula:\n `LEN({title tag})` or `LEN({meta desc})`\n* You can automate the process calling a Webhook from Airtable. For this, you need an Airtable paid plan."
},
"typeVersion": 1
}
],
"connections": {
"Get records": {
"main": [
[
{
"node": "Get url content",
"type": "main",
"index": 0
}
]
]
},
"Get url content": {
"main": [
[
{
"node": "Extract title tag and meta description",
"type": "main",
"index": 0
}
]
]
},
"When clicking \"Test workflow\"": {
"main": [
[
{
"node": "Get records",
"type": "main",
"index": 0
}
]
]
},
"Extract title tag and meta description": {
"main": [
[
{
"node": "Update original record",
"type": "main",
"index": 0
}
]
]
}
}
}
Credentials you'll need
Each integration node will prompt for credentials when you import. We strip credential IDs before publishing — you'll add your own.
airtableTokenApi
For the full experience including quality scoring and batch install features for each workflow upgrade to Pro
About this workflow
Extract Title tag and meta description from url for SEO analysis.
Source: https://n8n.io/workflows/2267/ — original creator credit. Request a take-down →
Related workflows
Workflows that share integrations, category, or trigger type with this one. All free to copy and import.
Lmchatopenai Workflow. Uses noOp, stickyNote, executeWorkflowTrigger, airtable. Event-driven trigger; 41 nodes.
This n8n workflow retrieves an Airtable record along with its related child records in a hierarchical structure. It can fetch up to 3 levels of linked records and assembles them into a comprehensive J
How it works
This workflow automatically pulls SERP rankings, competitor keywords, and related keyword ideas from DataForSEO and stores structured results in Airtable — making SEO tracking and keyword research str
d16-Web-Scraper-Data-Flow. Uses httpRequest, airtable, executeWorkflowTrigger. Event-driven trigger; 20 nodes.