Archivar páginas en blanco en la base de datos de Notion
Este es unBuilding Blocksflujo de automatización del dominio deautomatización que contiene 10 nodos.Utiliza principalmente nodos como If, Cron, Notion, Function, SplitInBatches. Archivar páginas en blanco en bases de datos de Notion
- •Clave de API de Notion
Nodos utilizados (10)
Categoría
{
"id": 115,
"name": "Archive empty pages in Notion Database",
"nodes": [
{
"name": "Obtener todas las bases de datos",
"type": "n8n-nodes-base.notion",
"position": [
240,
300
],
"parameters": {
"resource": "database",
"operation": "getAll",
"returnAll": true
},
"credentials": {
"notionApi": {
"id": "36",
"name": "Notion account"
}
},
"typeVersion": 2,
"id": "Obtener-todas-las-bases-de-datos-0"
},
{
"name": "Obtener todas las páginas de la base de datos",
"type": "n8n-nodes-base.notion",
"position": [
420,
300
],
"parameters": {
"simple": false,
"options": {},
"resource": "databasePage",
"operation": "getAll",
"returnAll": true,
"databaseId": "={{$json[\"id\"]}}"
},
"credentials": {
"notionApi": {
"id": "36",
"name": "Notion account"
}
},
"typeVersion": 2,
"id": "Obtener-todas-las-p-ginas-de-la-base-de-datos-1"
},
{
"name": "Obtener bloques de página",
"type": "n8n-nodes-base.notion",
"position": [
1180,
280
],
"parameters": {
"blockId": "={{$json[\"id\"]}}",
"resource": "block",
"operation": "getAll",
"returnAll": true
},
"credentials": {
"notionApi": {
"id": "36",
"name": "Notion account"
}
},
"typeVersion": 2,
"alwaysOutputData": true,
"id": "Obtener-bloques-de-p-gina-2"
},
{
"name": "Procesar bloques",
"type": "n8n-nodes-base.function",
"position": [
1360,
280
],
"parameters": {
"functionCode": "let returnData = {\n json: {\n toDelete: false,\n pageID: $node[\"SplitInBatches\"].json[\"id\"],\n }\n};\n\nif (!items[0].json.id) {\n returnData.json.toDelete = true;\n return [returnData];\n}\n\nfor (item of items) {\n \n let toDelete = false;\n\n let type = item.json.type;\n let data = item.json[type];\n\n if (!toDelete) {\n if (data.text.length == 0) {\n toDelete = true;\n } else {\n returnData.json.toDelete = false;\n break;\n }\n }\n\n returnData.json.toDelete = toDelete;\n}\n\nreturn [returnData];"
},
"typeVersion": 1,
"id": "Procesar-bloques-3"
},
{
"name": "Dividir en lotes",
"type": "n8n-nodes-base.splitInBatches",
"position": [
1000,
280
],
"parameters": {
"options": {},
"batchSize": 1
},
"typeVersion": 1,
"id": "Dividir-en-lotes-4"
},
{
"name": "Verificar propiedades vacías",
"type": "n8n-nodes-base.function",
"position": [
600,
300
],
"parameters": {
"functionCode": "for (item of items) {\n\n let toDelete = false;\n for (const key in item.json.properties) {\n let type = item.json.properties[key].type;\n let data = item.json.properties[key][type];\n \n if (!data || data.length == 0) {\n toDelete = true;\n } else {\n toDelete = false;\n break;\n }\n }\n\n item.json.toDelete = toDelete;\n}\n\nreturn items;"
},
"typeVersion": 1,
"id": "Verificar-propiedades-vac-as-5"
},
{
"name": "Archivar página",
"type": "n8n-nodes-base.notion",
"position": [
1760,
260
],
"parameters": {
"pageId": "={{$json[\"pageID\"]}}",
"operation": "archive"
},
"credentials": {
"notionApi": {
"id": "36",
"name": "Notion account"
}
},
"typeVersion": 2,
"id": "Archivar-p-gina-6"
},
{
"name": "Si eliminar",
"type": "n8n-nodes-base.if",
"position": [
1560,
280
],
"parameters": {
"conditions": {
"boolean": [
{
"value1": "={{$json[\"toDelete\"]}}",
"value2": true
}
]
}
},
"typeVersion": 1,
"id": "Si-eliminar-7"
},
{
"name": "Si propiedades vacías",
"type": "n8n-nodes-base.if",
"position": [
760,
300
],
"parameters": {
"conditions": {
"boolean": [
{
"value1": "={{$json[\"toDelete\"]}}",
"value2": true
}
]
}
},
"typeVersion": 1,
"id": "Si-propiedades-vac-as-8"
},
{
"name": "Cada día a las 2 a.m.",
"type": "n8n-nodes-base.cron",
"position": [
80,
300
],
"parameters": {
"triggerTimes": {
"item": [
{
"hour": 2
}
]
}
},
"typeVersion": 1,
"id": "Cada-d-a-a-las-2-a-m--9"
}
],
"active": false,
"settings": {},
"connections": {
"Si-eliminar-7": {
"main": [
[
{
"node": "Archivar-p-gina-6",
"type": "main",
"index": 0
}
]
]
},
"Procesar-bloques-3": {
"main": [
[
{
"node": "Si-eliminar-7",
"type": "main",
"index": 0
},
{
"node": "Dividir-en-lotes-4",
"type": "main",
"index": 0
}
]
]
},
"Dividir-en-lotes-4": {
"main": [
[
{
"node": "Obtener-bloques-de-p-gina-2",
"type": "main",
"index": 0
}
]
]
},
"Cada-d-a-a-las-2-a-m--9": {
"main": [
[
{
"node": "Obtener-todas-las-bases-de-datos-0",
"type": "main",
"index": 0
}
]
]
},
"Obtener-bloques-de-p-gina-2": {
"main": [
[
{
"node": "Procesar-bloques-3",
"type": "main",
"index": 0
}
]
]
},
"Obtener-todas-las-bases-de-datos-0": {
"main": [
[
{
"node": "Obtener-todas-las-p-ginas-de-la-base-de-datos-1",
"type": "main",
"index": 0
}
]
]
},
"Si-propiedades-vac-as-8": {
"main": [
[
{
"node": "Dividir-en-lotes-4",
"type": "main",
"index": 0
}
]
]
},
"Obtener-todas-las-p-ginas-de-la-base-de-datos-1": {
"main": [
[
{
"node": "Verificar-propiedades-vac-as-5",
"type": "main",
"index": 0
}
]
]
},
"Verificar-propiedades-vac-as-5": {
"main": [
[
{
"node": "Si-propiedades-vac-as-8",
"type": "main",
"index": 0
}
]
]
}
}
}¿Cómo usar este flujo de trabajo?
Copie el código de configuración JSON de arriba, cree un nuevo flujo de trabajo en su instancia de n8n y seleccione "Importar desde JSON", pegue la configuración y luego modifique la configuración de credenciales según sea necesario.
¿En qué escenarios es adecuado este flujo de trabajo?
Intermedio - Bloques de construcción
¿Es de pago?
Este flujo de trabajo es completamente gratuito, puede importarlo y usarlo directamente. Sin embargo, tenga en cuenta que los servicios de terceros utilizados en el flujo de trabajo (como la API de OpenAI) pueden requerir un pago por su cuenta.
Flujos de trabajo relacionados recomendados
Jonathan
@jon-n8nCompartir este flujo de trabajo