Workflow n8n

Automatisation Google Sheets avec n8n : collecte de données Product Hunt

Ce workflow n8n a pour objectif de simplifier la collecte quotidienne des données de Product Hunt et de les intégrer automatiquement dans Google Sheets. Idéal pour les équipes marketing et les entrepreneurs, il permet de suivre les nouvelles tendances et produits lancés chaque jour sans intervention manuelle. En utilisant ce workflow, vous pouvez gagner un temps précieux et vous concentrer sur l'analyse des données plutôt que sur leur collecte.

  • Étape 1 : Le workflow est déclenché par un événement planifié grâce au nœud 'Daily Trigger1', qui exécute le processus à une heure définie chaque jour.
  • Étape 2 : La date actuelle est définie avec le nœud 'Set Date1', ce qui permet de récupérer les publications du jour.
  • Étape 3 : Le nœud 'Fetches today’s Product Hunt posts via API' interroge l'API de Product Hunt pour obtenir les publications du jour.
  • Étape 4 : Les informations des produits sont extraites à l'aide du nœud 'Extracts Product Info', qui traite les données reçues.
  • Étape 5 : Les URL des sites sont résolues avec le nœud 'Resolve Website Redirection', garantissant que toutes les redirections sont correctement gérées.
  • Étape 6 : Les données sont ensuite organisées et fusionnées avec le nœud 'Merge Data', avant d'être envoyées vers Google Sheets via le nœud 'Appends all details'. Ce workflow offre une solution efficace pour automatiser la collecte de données, réduisant ainsi les risques d'erreurs humaines et augmentant la productivité. En intégrant directement les données dans Google Sheets, les utilisateurs peuvent facilement analyser et partager les informations pertinentes avec leur équipe.
Tags clés :automatisationGoogle SheetsProduct Huntn8ncollecte de données
Catégorie: Scheduled · Tags: automatisation, Google Sheets, Product Hunt, n8n, collecte de données0

Workflow n8n Google Sheets, Product Hunt, collecte de données : 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, Product Hunt, collecte de données : détail des nœuds

  • Daily Trigger1

    Déclenche le workflow quotidiennement selon la règle spécifiée.

  • Set Date1

    Définit une date spécifique à utiliser dans le workflow.

  • Sticky Note16

    Affiche une note autocollante contenant le contenu spécifié.

  • Sticky Note17

    Affiche une note autocollante avec une largeur, une hauteur et un contenu définis.

  • Fetches today’s Product Hunt posts via API.

    Récupère les publications du jour sur Product Hunt via une requête API.

  • Extracts Product Info

    Extrait les informations sur les produits à l'aide d'un code JavaScript.

  • Resolve Website Redirection

    Résout les redirections de site web en effectuant une requête HTTP.

  • Data 2 (website url)

    Définit des données pour l'URL du site web dans le workflow.

  • Data 1 (product info)

    Définit des données pour les informations sur le produit dans le workflow.

  • Merge Data

    Fusionne les données en utilisant un code de fonction personnalisé.

  • Appends all details

    Ajoute tous les détails dans une feuille Google Sheets selon les colonnes spécifiées.

  • Sticky Note18

    Affiche une note autocollante avec une largeur, une hauteur et un contenu définis.

Inscris-toi pour voir l'intégralité du workflow

Inscription gratuite

S'inscrire gratuitementBesoin d'aide ?
{
  "meta": {
    "instanceId": "431926ace0ab32761b92304a05ffb4819a2a2a8ee5de45404953945769b5412a"
  },
  "nodes": [
    {
      "id": "53bf4cb6-8f55-4d8d-b4af-48345f75cdd5",
      "name": "Daily Trigger1",
      "type": "n8n-nodes-base.scheduleTrigger",
      "position": [
        -660,
        6580
      ],
      "parameters": {
        "rule": {
          "interval": [
            {}
          ]
        }
      },
      "typeVersion": 1
    },
    {
      "id": "774624c1-cb4d-4355-9ed7-448d393c5f3b",
      "name": "Set Date1",
      "type": "n8n-nodes-base.set",
      "position": [
        -440,
        6580
      ],
      "parameters": {
        "values": {
          "string": [
            {
              "name": "today",
              "value": "={{ new Date().toISOString().split('T')[0] }}"
            }
          ]
        },
        "options": {}
      },
      "typeVersion": 1
    },
    {
      "id": "951eb189-8143-48d7-88c9-3ce235de83f6",
      "name": "Sticky Note16",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        -260,
        6400
      ],
      "parameters": {
        "content": "### 🔐 How to Get Your Product Hunt Token\n\nTo get your Product Hunt token, follow the official guide here:  \n👉 [Product Hunt OAuth Token Guide](https://api.producthunt.com/v2/docs/oauth_user_authentication/oauth_authorize_ask_for_access_grant_code_on_behalf_of_the_user)\n"
      },
      "typeVersion": 1
    },
    {
      "id": "ae83bb19-a981-4b28-8dcd-ecd9501bd3d0",
      "name": "Sticky Note17",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        820,
        6280
      ],
      "parameters": {
        "width": 360,
        "height": 280,
        "content": "### 📄 How to Connect Google Sheets in n8n\n\nTo connect your Google Sheets to n8n:\n\n1. Go to your n8n Credentials page.\n2. Select **Google Sheets** and add new credentials.\n3. Authenticate your Google account and give the required permissions.\n\nFollow the full guide here:  \n👉 https://www.youtube.com/watch?v=pWGXlZBGu4k\n"
      },
      "typeVersion": 1
    },
    {
      "id": "4a0c04d4-3ce2-4ebb-94a3-2a0441e25e23",
      "name": "Fetches today’s Product Hunt posts via API.",
      "type": "n8n-nodes-base.httpRequest",
      "notes": "### 🔐 How to Get Your Product Hunt Token\n\nTo get your Product Hunt token, follow the official guide here:  \n👉 [Product Hunt OAuth Token Guide](https://api.producthunt.com/v2/docs/oauth_user_authentication/oauth_authorize_ask_for_access_grant_code_on_behalf_of_the_user)\n",
      "position": [
        -220,
        6580
      ],
      "parameters": {
        "url": "https://api.producthunt.com/v2/api/graphql",
        "method": "POST",
        "options": {},
        "sendBody": true,
        "sendHeaders": true,
        "bodyParameters": {
          "parameters": [
            {
              "name": "query",
              "value": "query {   posts(first: 10, postedAfter: \"{{ $node[\\\"Set Date1\\\"].json[\\\"today\\\"] }}T00:00:00Z\", postedBefore: \"{{ $node[\\\"Set Date1\\\"].json[\\\"today\\\"] }}T23:59:59Z\") {     edges {       node {         name         tagline         description         website       }       cursor     }     pageInfo {       hasNextPage       endCursor     }   } }"
            }
          ]
        },
        "headerParameters": {
          "parameters": [
            {
              "name": "Authorization",
              "value": "=Bearer YOUR_PRODUCT_HUNT_API_KEY"
            },
            {
              "name": "User-Agent",
              "value": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36"
            }
          ]
        }
      },
      "notesInFlow": false,
      "typeVersion": 4.2
    },
    {
      "id": "994c8a22-ce3a-42cf-95e1-9512f1525fd7",
      "name": "Extracts Product Info",
      "type": "n8n-nodes-base.code",
      "position": [
        0,
        6580
      ],
      "parameters": {
        "jsCode": "return $json.data.posts.edges.map(edge => {\n  return {\n    json: {\n      name: edge.node.name,\n      tagline: edge.node.tagline,\n      description: edge.node.description,\n      website: edge.node.website\n    }\n  };\n});\n"
      },
      "typeVersion": 2
    },
    {
      "id": "f7846147-cd50-4b5e-bb79-0f17ff7d5900",
      "name": "Resolve Website Redirection",
      "type": "n8n-nodes-base.httpRequest",
      "position": [
        220,
        6680
      ],
      "parameters": {
        "url": "={{ $json.website }}\n",
        "options": {
          "fullResponse": true,
          "followRedirect": false,
          "followAllRedirects": false,
          "ignoreResponseCode": true
        },
        "responseFormat": "string",
        "dataPropertyName": "body",
        "allowUnauthorizedCerts": true
      },
      "typeVersion": 1
    },
    {
      "id": "11f5df7a-bc46-4ae6-b97d-0ce8c15d804d",
      "name": "Data  2 (website url)",
      "type": "n8n-nodes-base.set",
      "position": [
        440,
        6680
      ],
      "parameters": {
        "values": {
          "string": [
            {
              "name": "next_url",
              "value": "={{$json[\"headers\"][\"location\"]}}"
            }
          ]
        },
        "options": {},
        "keepOnlySet": true
      },
      "typeVersion": 1
    },
    {
      "id": "3fd9b50e-c30b-44dd-ac53-83b0a597db2e",
      "name": "Data 1 (product info)",
      "type": "n8n-nodes-base.set",
      "position": [
        440,
        6480
      ],
      "parameters": {
        "values": {
          "string": [
            {
              "name": "name",
              "value": "={{ $json.name }}"
            },
            {
              "name": "tagline",
              "value": "={{ $json.tagline }}"
            },
            {
              "name": "description",
              "value": "={{ $json.description }}"
            }
          ]
        },
        "options": {},
        "keepOnlySet": true
      },
      "typeVersion": 1
    },
    {
      "id": "68acc44b-10cd-4bae-bf01-b304cd753f15",
      "name": "Merge Data",
      "type": "n8n-nodes-base.function",
      "position": [
        660,
        6580
      ],
      "parameters": {
        "functionCode": "// Initialize empty arrays for both data sources\nlet productData = [];\nlet redirectData = [];\n\ntry {\n  productData = $items(\"Data to Keep4\");\n} catch (error) {\n  console.log(\"Error fetching product data:\", error.message);\n}\n\ntry {\n  redirectData = $items(\"Data to Keep3\");\n} catch (error) {\n  console.log(\"Error fetching redirect data:\", error.message);\n}\n\nconst mergedItems = [];\n\nfor (let i = 0; i < productData.length; i++) {\n  const product = productData[i].json;\n  \n  const mergedItem = {\n    name: product.name,\n    tagline: product.tagline,\n    description: product.description,\n    next_url: null\n  };\n  \n  if (i < redirectData.length && redirectData[i] && redirectData[i].json) {\n    let url = redirectData[i].json.next_url;\n    // Remove ?ref=producthunt from the URL\n    if (url && url.includes('?ref=producthunt')) {\n      url = url.replace('?ref=producthunt', '');\n    }\n    mergedItem.next_url = url;\n  }\n  \n  mergedItems.push({ json: mergedItem });\n}\n\nconsole.log(`Product data items: ${productData.length}`);\nconsole.log(`Redirect data items: ${redirectData.length}`);\nconsole.log(`Merged items: ${mergedItems.length}`);\n\nreturn mergedItems;"
      },
      "typeVersion": 1
    },
    {
      "id": "39429f34-19d1-488a-9603-7b25f6042fa6",
      "name": "Appends all details",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        880,
        6580
      ],
      "parameters": {
        "columns": {
          "value": {
            "name": "={{ $json.name }}",
            "tagline": "={{ $json.tagline }}",
            "description": "={{ $json.description }}"
          },
          "schema": [
            {
              "id": "name",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "name",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "tagline",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "tagline",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "description",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "description",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "next_url",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "next_url",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            }
          ],
          "mappingMode": "autoMapInputData",
          "matchingColumns": [
            "name"
          ],
          "attemptToConvertTypes": false,
          "convertFieldsToString": false
        },
        "options": {},
        "operation": "appendOrUpdate",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "demo",
          "cachedResultName": "Sheet1"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "demo",
          "cachedResultUrl": "demo",
          "cachedResultName": "Get product hunt products"
        },
        "authentication": "serviceAccount"
      },
      "typeVersion": 4.5
    },
    {
      "id": "6be5f1a1-c6e9-4dea-9199-523cd7f4b659",
      "name": "Sticky Note18",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        -980,
        6380
      ],
      "parameters": {
        "width": 280,
        "height": 260,
        "content": "### About Me  \n\nHey there! I’m **Ajetomobi Ifeoluwa** – the brains (and vibe) behind this template. When I’m not crafting cool workflows, I’m busy making the web more beautiful and functional as a **UI/UX Designer** and **Vibe Coder**. Want your project to stand out? Let’s chat! Check out my [portfolio](https://ifeoluwaajetomobi.framer.website/) and my work on [Behance](https://www.behance.net/ajetomoifeoluw). Let’s create something awesome together! 🎨✨\n\n"
      },
      "typeVersion": 1
    }
  ],
  "pinData": {},
  "connections": {
    "Set Date1": {
      "main": [
        [
          {
            "node": "Fetches today’s Product Hunt posts via API.",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Merge Data": {
      "main": [
        [
          {
            "node": "Appends all details",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Daily Trigger1": {
      "main": [
        [
          {
            "node": "Set Date1",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Data  2 (website url)": {
      "main": [
        [
          {
            "node": "Merge Data",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Data 1 (product info)": {
      "main": [
        [
          {
            "node": "Merge Data",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Extracts Product Info": {
      "main": [
        [
          {
            "node": "Resolve Website Redirection",
            "type": "main",
            "index": 0
          },
          {
            "node": "Data 1 (product info)",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Resolve Website Redirection": {
      "main": [
        [
          {
            "node": "Data  2 (website url)",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Fetches today’s Product Hunt posts via API.": {
      "main": [
        [
          {
            "node": "Extracts Product Info",
            "type": "main",
            "index": 0
          }
        ]
      ]
    }
  }
}

Workflow n8n Google Sheets, Product Hunt, collecte de données : pour qui est ce workflow ?

Ce workflow s'adresse aux équipes marketing, aux entrepreneurs et aux startups qui souhaitent automatiser la collecte de données sur les nouveaux produits. Un niveau technique de base est recommandé pour une personnalisation efficace.

Workflow n8n Google Sheets, Product Hunt, collecte de données : problème résolu

Ce workflow résout le problème de la collecte manuelle des données de Product Hunt, qui peut être chronophage et sujette à des erreurs. En automatisant ce processus, les utilisateurs éliminent les frustrations liées à la recherche quotidienne d'informations, réduisent le risque d'oublis et obtiennent des données à jour directement dans Google Sheets. Cela leur permet de se concentrer sur l'analyse et l'utilisation stratégique de ces informations.

Workflow n8n Google Sheets, Product Hunt, collecte de données : étapes du workflow

Étape 1 : Le workflow est déclenché quotidiennement par le nœud 'Daily Trigger1'.

  • Étape 1 : La date actuelle est définie avec le nœud 'Set Date1'.
  • Étape 2 : Les publications de Product Hunt sont récupérées via le nœud 'Fetches today’s Product Hunt posts via API'.
  • Étape 3 : Les informations des produits sont extraites avec le nœud 'Extracts Product Info'.
  • Étape 4 : Les redirections des sites sont résolues grâce au nœud 'Resolve Website Redirection'.
  • Étape 5 : Les données sont organisées dans le nœud 'Merge Data', puis envoyées à Google Sheets avec le nœud 'Appends all details'.

Workflow n8n Google Sheets, Product Hunt, collecte de données : guide de personnalisation

Pour personnaliser ce workflow, vous pouvez modifier l'URL de l'API de Product Hunt dans le nœud 'Fetches today’s Product Hunt posts via API'. Assurez-vous également d'ajuster le nom de la feuille et l'ID du document dans le nœud 'Appends all details' pour correspondre à votre Google Sheet. Si vous souhaitez ajouter d'autres sources de données, vous pouvez intégrer des nœuds HTTP supplémentaires. Pensez à sécuriser votre API en utilisant des clés d'authentification appropriées et à surveiller le flux pour détecter d'éventuelles erreurs.