Constructeur de listes

Intermédiaire

Ceci est unSales, Finance, Product, AI, Marketingworkflow d'automatisation du domainecontenant 7 nœuds.Utilise principalement des nœuds comme Set, Code, Airtop, GoogleSheets, ManualTrigger, combinant la technologie d'intelligence artificielle pour une automatisation intelligente. Construire une liste de profils depuis n'importe quelle plateforme avec Airtop et Google Sheets

Prérequis
  • Informations d'identification Google Sheets API
Aperçu du workflow
Visualisation des connexions entre les nœuds, avec support du zoom et du déplacement
Exporter le workflow
Copiez la configuration JSON suivante dans n8n pour importer et utiliser ce workflow
{
  "id": "VwU1zMhcgzgPS9ak",
  "meta": {
    "instanceId": "660cf2c29eb19fa42319afac3bd2a4a74c6354b7c006403f6cba388968b63f5d",
    "templateCredsSetupCompleted": true
  },
  "name": "List Builder",
  "tags": [
    {
      "id": "a8B9vqj0vNLXcKVQ",
      "name": "template",
      "createdAt": "2025-04-04T15:38:37.785Z",
      "updatedAt": "2025-04-04T15:38:37.785Z"
    }
  ],
  "nodes": [
    {
      "id": "1a6aa574-467d-40b0-a9a5-a5537bede3de",
      "name": "Lors du clic sur 'Tester le workflow'",
      "type": "n8n-nodes-base.manualTrigger",
      "position": [
        0,
        0
      ],
      "parameters": {},
      "typeVersion": 1
    },
    {
      "id": "62db9366-7e6f-4346-9de8-9fa730d059ed",
      "name": "Formater les résultats",
      "type": "n8n-nodes-base.code",
      "position": [
        660,
        0
      ],
      "parameters": {
        "jsCode": "// Get first input item\nconst input = $input.first().json.data.modelResponse\n// Parse list of links\nconst listOfLinks = JSON.parse(input).results\n// Format node's output\nconst output = listOfLinks.map((item) => ({\n  json: { url: item.url }\n}))\n\nreturn output;"
      },
      "typeVersion": 2
    },
    {
      "id": "fa960de3-8dd6-40a3-aa59-634ad250f5d1",
      "name": "Obtenir les URLs",
      "type": "n8n-nodes-base.airtop",
      "position": [
        440,
        0
      ],
      "parameters": {
        "url": "=https://www.google.com/search?q={{ encodeURI($json.who+' on ' + $json.where) }}",
        "prompt": "=Those are search results, return up to 10 non-sponsored results that lead to a web page with a list of {{$json.who}} on {{$json.where}}. For each return the title and URL.",
        "resource": "extraction",
        "operation": "query",
        "sessionMode": "new",
        "additionalFields": {
          "outputSchema": "{  \"type\": \"object\",  \"properties\": {    \"results\": {      \"type\": \"array\",      \"items\": {        \"type\": \"object\",        \"properties\": {          \"title\": {            \"type\": \"string\",            \"description\": \"The title of the search result.\"          },          \"url\": {            \"type\": \"string\",            \"description\": \"The URL of the webpage.\"          }        },        \"required\": [          \"title\",          \"url\"        ],        \"additionalProperties\": false      },      \"description\": \"A list of up to 10 non-sponsored search results.\"    }  },  \"required\": [    \"results\"  ],  \"additionalProperties\": false,  \"$schema\": \"http://json-schema.org/draft-07/schema#\"}"
        }
      },
      "credentials": {
        "airtopApi": {
          "id": "byhouJF8RLH5DkmY",
          "name": "Airtop"
        }
      },
      "typeVersion": 1
    },
    {
      "id": "d75dbdce-7a7e-4a30-81b0-6e8fa5221f55",
      "name": "Obtenir les personnes",
      "type": "n8n-nodes-base.airtop",
      "position": [
        880,
        0
      ],
      "parameters": {
        "url": "={{ $json.url }}",
        "prompt": "=This is a list of {{ $('Parameters').item.json.who }} on {{ $('Parameters').item.json.where }}.\nExtract up to 20 items. For each person extract: \n- name \n- handle or ID \n- URL",
        "resource": "extraction",
        "operation": "query",
        "sessionMode": "new",
        "additionalFields": {
          "outputSchema": "{\n  \"$schema\": \"http://json-schema.org/draft-07/schema#\",\n  \"type\": \"object\",\n  \"properties\": {\n    \"items\": {\n      \"type\": \"array\",\n      \"items\": {\n        \"type\": \"object\",\n        \"properties\": {\n          \"name\": {\n            \"type\": \"string\",\n            \"description\": \"The name of the item.\"\n          },\n          \"identifier\": {\n            \"type\": \"string\",\n            \"description\": \"The unique identifier or handle for the item.\"\n          },\n          \"url\": {\n            \"type\": \"string\",\n            \"description\": \"The URL to access the item or its related resource.\"\n          }\n        },\n        \"required\": [\n          \"name\",\n          \"identifier\",\n          \"url\"\n        ],\n        \"additionalProperties\": false\n      }\n    }\n  },\n  \"required\": [\n    \"items\"\n  ],\n  \"additionalProperties\": false\n}"
        }
      },
      "credentials": {
        "airtopApi": {
          "id": "byhouJF8RLH5DkmY",
          "name": "Airtop"
        }
      },
      "typeVersion": 1
    },
    {
      "id": "285ce6af-bda8-4025-872e-f5f8c4a56b3c",
      "name": "Dédupliquer les résultats",
      "type": "n8n-nodes-base.code",
      "position": [
        1100,
        0
      ],
      "parameters": {
        "jsCode": "const allResults = []\n\nfor (const inputItem of $input.all()) {\n  // Parse input to JSON\n  const input = inputItem.json.data.modelResponse\n  const results = JSON.parse(input).items\n  // clean results\n  const cleanedResults = results\n    .filter((res) => res.name) // only those with name\n    .map((res) => ({\n      ...res,\n      url: res.url.split('?')[0] // clean url\n    }))\n  // add results to list\n  allResults.push(...cleanedResults)\n}\n\n// Dedupe urls\nconst uniqueList = allResults.filter((item, index, self) =>\n  index === self.findIndex((t) => (t.url === item.url))\n);\n\nreturn uniqueList.map((item) => ({\n  json: {...item}\n}));"
      },
      "typeVersion": 2
    },
    {
      "id": "fdc86d5c-4df3-48b9-9cf6-a5ddc3b45c90",
      "name": "Ajouter au tableur",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        1320,
        0
      ],
      "parameters": {
        "columns": {
          "value": {
            "URL": "={{ $json.url }}",
            "Name": "={{ $json.name }}",
            "Who?": "={{ $('Parameters').first().json.who }}",
            "Where?": "={{ $('Parameters').first().json.where }}",
            "Added on": "={{ $now }}",
            "ID or Handle": "={{ $json.identifier }}"
          },
          "schema": [
            {
              "id": "Who?",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Who?",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Where?",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Where?",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Name",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Name",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "ID or Handle",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "ID or Handle",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "URL",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "URL",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Added on",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Added on",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            }
          ],
          "mappingMode": "defineBelow",
          "matchingColumns": [],
          "attemptToConvertTypes": false,
          "convertFieldsToString": false
        },
        "options": {},
        "operation": "append",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/150eh4t5GyEBN_TcO5TDeNWpE2GzHR4hQWoNRbUpw7A0/edit#gid=0",
          "cachedResultName": "Sheet1"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "150eh4t5GyEBN_TcO5TDeNWpE2GzHR4hQWoNRbUpw7A0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/150eh4t5GyEBN_TcO5TDeNWpE2GzHR4hQWoNRbUpw7A0/edit?usp=drivesdk",
          "cachedResultName": "List Builder"
        }
      },
      "credentials": {
        "googleSheetsOAuth2Api": {
          "id": "CwpCAR1HwgHZpRtJ",
          "name": "Google Drive"
        }
      },
      "typeVersion": 4.5
    },
    {
      "id": "44c54497-741c-4c48-b4f9-0c5c836d10ad",
      "name": "Paramètres",
      "type": "n8n-nodes-base.set",
      "position": [
        220,
        0
      ],
      "parameters": {
        "options": {},
        "assignments": {
          "assignments": [
            {
              "id": "bc2d3cb9-b7d0-4c3f-b392-53262d60441e",
              "name": "who",
              "type": "string",
              "value": "Top \"Build in Public\" influencers"
            },
            {
              "id": "b2cfa361-c80a-4945-bc0e-23eac5edebd6",
              "name": "where",
              "type": "string",
              "value": "X"
            }
          ]
        }
      },
      "typeVersion": 3.4
    }
  ],
  "active": false,
  "pinData": {},
  "settings": {
    "executionOrder": "v1"
  },
  "versionId": "a2572aec-54cb-4bbb-b503-09d1d0beb64f",
  "connections": {
    "fa960de3-8dd6-40a3-aa59-634ad250f5d1": {
      "main": [
        [
          {
            "node": "62db9366-7e6f-4346-9de8-9fa730d059ed",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "d75dbdce-7a7e-4a30-81b0-6e8fa5221f55": {
      "main": [
        [
          {
            "node": "285ce6af-bda8-4025-872e-f5f8c4a56b3c",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "44c54497-741c-4c48-b4f9-0c5c836d10ad": {
      "main": [
        [
          {
            "node": "fa960de3-8dd6-40a3-aa59-634ad250f5d1",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "285ce6af-bda8-4025-872e-f5f8c4a56b3c": {
      "main": [
        [
          {
            "node": "fdc86d5c-4df3-48b9-9cf6-a5ddc3b45c90",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "62db9366-7e6f-4346-9de8-9fa730d059ed": {
      "main": [
        [
          {
            "node": "d75dbdce-7a7e-4a30-81b0-6e8fa5221f55",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "1a6aa574-467d-40b0-a9a5-a5537bede3de": {
      "main": [
        [
          {
            "node": "44c54497-741c-4c48-b4f9-0c5c836d10ad",
            "type": "main",
            "index": 0
          }
        ]
      ]
    }
  }
}
Foire aux questions

Comment utiliser ce workflow ?

Copiez le code de configuration JSON ci-dessus, créez un nouveau workflow dans votre instance n8n et sélectionnez "Importer depuis le JSON", collez la configuration et modifiez les paramètres d'authentification selon vos besoins.

Dans quelles scénarios ce workflow est-il adapté ?

Intermédiaire - Ventes, Finance, Produit, Intelligence Artificielle, Marketing

Est-ce payant ?

Ce workflow est entièrement gratuit et peut être utilisé directement. Veuillez noter que les services tiers utilisés dans le workflow (comme l'API OpenAI) peuvent nécessiter un paiement de votre part.

Informations sur le workflow
Niveau de difficulté
Intermédiaire
Nombre de nœuds7
Catégorie5
Types de nœuds5
Description de la difficulté

Adapté aux utilisateurs expérimentés, avec des workflows de complexité moyenne contenant 6-15 nœuds

Auteur
Cesar @ Airtop AI

Cesar @ Airtop AI

@cesar-at-airtop

AI Engineer at Airtop AI

Liens externes
Voir sur n8n.io

Partager ce workflow

Catégories

Catégories: 34