Cal.com と Google Sheets を使用した面接スケジュールとデータクリーニングの自動化

中級

これはHR分野の自動化ワークフローで、14個のノードを含みます。主にIf, Set, Code, SplitOut, HttpRequestなどのノードを使用。 Cal.comとGoogle Sheetsを使って、インタビュー予定調整とデータクリーニングを自動化

前提条件
  • ターゲットAPIの認証情報が必要な場合あり
  • Google Sheets API認証情報

カテゴリー

ワークフロープレビュー
ノード接続関係を可視化、ズームとパンをサポート
ワークフローをエクスポート
以下のJSON設定をn8nにインポートして、このワークフローを使用できます
{
  "meta": {
    "instanceId": "60098b76ad738e2ce8a403a46a5d6afed7799cdb6caa43f6858e6df2ac2bc8f5",
    "templateCredsSetupCompleted": true
  },
  "nodes": [
    {
      "id": "da1d59c5-9f44-41b2-9239-9656a5524bc8",
      "name": "ワークフロー実行時",
      "type": "n8n-nodes-base.manualTrigger",
      "position": [
        60,
        60
      ],
      "parameters": {},
      "typeVersion": 1
    },
    {
      "id": "be3c688c-ca01-42b8-8fd6-6b715a187683",
      "name": "HTTPリクエスト1",
      "type": "n8n-nodes-base.httpRequest",
      "position": [
        560,
        60
      ],
      "parameters": {
        "url": "https://api.cal.com/v1/bookings",
        "options": {},
        "sendQuery": true,
        "queryParameters": {
          "parameters": [
            {
              "name": "apiKey",
              "value": "YOUR API KEY HERE"
            },
            {
              "name": "id",
              "value": "={{ $json.attendees[0].bookingId }}"
            }
          ]
        }
      },
      "typeVersion": 4.2
    },
    {
      "id": "ba372028-e10d-46c8-bac9-eb3400e5c2f4",
      "name": "フィールド編集1",
      "type": "n8n-nodes-base.set",
      "position": [
        960,
        60
      ],
      "parameters": {
        "include": "selected",
        "options": {},
        "assignments": {
          "assignments": [
            {
              "id": "7084df2d-5689-48c1-a048-2a3861261073",
              "name": "Email",
              "type": "string",
              "value": "={{ $json.email.toLowerCase() }}"
            },
            {
              "id": "320d00bf-cc25-46b5-b4e9-ee4ecd45db66",
              "name": "Interview Schedule",
              "type": "string",
              "value": "={{ $json.startFormatted }}"
            }
          ]
        },
        "includeOtherFields": true
      },
      "typeVersion": 3.4
    },
    {
      "id": "b9c03922-faf8-4c5c-87ba-cd44b8919aaa",
      "name": "Google Sheets1",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        1440,
        60
      ],
      "parameters": {
        "options": {},
        "filtersUI": {
          "values": [
            {
              "lookupColumn": "SUMMARY "
            }
          ]
        },
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit#gid=0",
          "cachedResultName": "Accepted"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit?usp=drivesdk",
          "cachedResultName": "Resumes"
        }
      },
      "credentials": {},
      "typeVersion": 4.6
    },
    {
      "id": "06ea5046-9679-47d3-876c-d9963a5bd47c",
      "name": "分割",
      "type": "n8n-nodes-base.splitOut",
      "position": [
        1660,
        60
      ],
      "parameters": {
        "include": "allOtherFields",
        "options": {},
        "fieldToSplitOut": "Email"
      },
      "typeVersion": 1
    },
    {
      "id": "8d2456b4-8074-4b95-9f2d-9beca4f47f3a",
      "name": "付箋1",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        220,
        -260
      ],
      "parameters": {
        "content": "## 📅 Cal.com Calendar Setup\nThis section fetches all bookings from your Cal.com event.\n\n- Pulls booking data via Cal.com API\n- Extracts attendee name, email, and interview time\n\n🔐 Be sure to insert your Cal.com API Key."
      },
      "typeVersion": 1
    },
    {
      "id": "73f5783e-f0e4-40e8-88e2-067bc86880b3",
      "name": "付箋4",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        940,
        -280
      ],
      "parameters": {
        "color": 3,
        "width": 420,
        "height": 280,
        "content": "## 🔁 Link to Resume Screening Template\nThis workflow can be connected to the resume evaluation system.\n\n- Automatically assigns interview schedules\n- Matches bookings to existing applicants in your sheet\n\n📌 Useful for aligning candidate records with scheduled interviews."
      },
      "typeVersion": 1
    },
    {
      "id": "4c2e0432-6b9c-4142-a17f-cb65cd31697e",
      "name": "付箋5",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        1820,
        -220
      ],
      "parameters": {
        "width": 460,
        "height": 220,
        "content": "## 🧹 Data Cleanup Logic\nThis section ensures only valid candidates remain in the sheet.\n\n- Compares booking emails with accepted applicants\n- Deletes rows with missing or unmatched data (e.g. no summary)\n\n✅ Keeps your applicant tracking clean and relevant."
      },
      "typeVersion": 1
    },
    {
      "id": "f61ef94a-6f49-4495-aa2c-9d4e8e3c02fd",
      "name": "メールの反復処理",
      "type": "n8n-nodes-base.splitInBatches",
      "position": [
        1900,
        60
      ],
      "parameters": {
        "options": {}
      },
      "typeVersion": 3
    },
    {
      "id": "e896a142-0045-4b18-bb84-23381fda6343",
      "name": "不一致メールの確認",
      "type": "n8n-nodes-base.if",
      "position": [
        2120,
        160
      ],
      "parameters": {
        "options": {},
        "conditions": {
          "options": {
            "version": 2,
            "leftValue": "",
            "caseSensitive": true,
            "typeValidation": "strict"
          },
          "combinator": "and",
          "conditions": [
            {
              "id": "8aa988a0-0225-49fc-9953-e97746bc7c9b",
              "operator": {
                "name": "filter.operator.equals",
                "type": "string",
                "operation": "equals"
              },
              "leftValue": "={{ $json['SUMMARY '] }}",
              "rightValue": "="
            }
          ]
        }
      },
      "typeVersion": 2.2
    },
    {
      "id": "231eee7f-33cc-4879-ab32-701543a83ec2",
      "name": "削除",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        2340,
        140
      ],
      "parameters": {
        "operation": "delete",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit#gid=0",
          "cachedResultName": "Accepted"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit?usp=drivesdk",
          "cachedResultName": "Resumes"
        },
        "startIndex": "={{ $json.row_number }}"
      },
      "credentials": {},
      "typeVersion": 4.6
    },
    {
      "id": "7fa5068c-5b7c-4bb5-bd0c-a41560221141",
      "name": "面接の日時追加",
      "type": "n8n-nodes-base.googleSheets",
      "position": [
        1200,
        60
      ],
      "parameters": {
        "columns": {
          "value": {},
          "schema": [
            {
              "id": "NAME",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "NAME",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Email",
              "type": "string",
              "display": true,
              "removed": false,
              "required": false,
              "displayName": "Email",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Phone Number",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Phone Number",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "JUSTIFICATION ",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "JUSTIFICATION ",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "SUMMARY ",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "SUMMARY ",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Q1",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Q1",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Q2",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Q2",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Q3",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Q3",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Q4",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Q4",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            },
            {
              "id": "Q5",
              "type": "string",
              "display": true,
              "required": false,
              "displayName": "Q5",
              "defaultMatch": false,
              "canBeUsedToMatch": true
            }
          ],
          "mappingMode": "autoMapInputData",
          "matchingColumns": [
            "Email"
          ],
          "attemptToConvertTypes": false,
          "convertFieldsToString": false
        },
        "options": {
          "handlingExtraData": "ignoreIt"
        },
        "operation": "appendOrUpdate",
        "sheetName": {
          "__rl": true,
          "mode": "list",
          "value": "gid=0",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit#gid=0",
          "cachedResultName": "Accepted"
        },
        "documentId": {
          "__rl": true,
          "mode": "list",
          "value": "18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY",
          "cachedResultUrl": "https://docs.google.com/spreadsheets/d/18vvSKGbAiodQvNsdNTJ1pBuhEcv2ADAmQKtDNAK7VQY/edit?usp=drivesdk",
          "cachedResultName": "Resumes"
        }
      },
      "credentials": {},
      "typeVersion": 4.6
    },
    {
      "id": "a30e3a25-b55e-41bd-bd25-ac6821bdec32",
      "name": "時間への変換",
      "type": "n8n-nodes-base.code",
      "position": [
        760,
        60
      ],
      "parameters": {
        "jsCode": "return $json.bookings.map(booking => {\n  const date = new Date(booking.startTime);\n  const formatted = date.toLocaleString(\"en-GB\", {\n    timeZone: \"Asia/Riyadh\",\n    day: \"2-digit\",\n    month: \"long\",\n    hour: \"2-digit\",\n    minute: \"2-digit\",\n    hour12: true\n  });\n\n  return {\n    json: {\n      name: booking.attendees[0].name,\n      email: booking.attendees[0].email,\n      startFormatted: formatted\n    }\n  };\n});\n"
      },
      "typeVersion": 2
    },
    {
      "id": "365dad27-686d-4f38-9bbd-6beeb83573ca",
      "name": "予約情報の取得",
      "type": "n8n-nodes-base.httpRequest",
      "position": [
        340,
        60
      ],
      "parameters": {
        "url": "https://api.cal.com/v1/attendees",
        "options": {},
        "sendQuery": true,
        "queryParameters": {
          "parameters": [
            {
              "name": "apiKey",
              "value": "your API KEY HERE"
            }
          ]
        }
      },
      "typeVersion": 4.2
    }
  ],
  "pinData": {},
  "connections": {
    "231eee7f-33cc-4879-ab32-701543a83ec2": {
      "main": [
        [
          {
            "node": "f61ef94a-6f49-4495-aa2c-9d4e8e3c02fd",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "06ea5046-9679-47d3-876c-d9963a5bd47c": {
      "main": [
        [
          {
            "node": "f61ef94a-6f49-4495-aa2c-9d4e8e3c02fd",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "ba372028-e10d-46c8-bac9-eb3400e5c2f4": {
      "main": [
        [
          {
            "node": "7fa5068c-5b7c-4bb5-bd0c-a41560221141",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "be3c688c-ca01-42b8-8fd6-6b715a187683": {
      "main": [
        [
          {
            "node": "a30e3a25-b55e-41bd-bd25-ac6821bdec32",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "b9c03922-faf8-4c5c-87ba-cd44b8919aaa": {
      "main": [
        [
          {
            "node": "06ea5046-9679-47d3-876c-d9963a5bd47c",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "a30e3a25-b55e-41bd-bd25-ac6821bdec32": {
      "main": [
        [
          {
            "node": "ba372028-e10d-46c8-bac9-eb3400e5c2f4",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "f61ef94a-6f49-4495-aa2c-9d4e8e3c02fd": {
      "main": [
        [],
        [
          {
            "node": "e896a142-0045-4b18-bb84-23381fda6343",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "e896a142-0045-4b18-bb84-23381fda6343": {
      "main": [
        [
          {
            "node": "231eee7f-33cc-4879-ab32-701543a83ec2",
            "type": "main",
            "index": 0
          }
        ],
        [
          {
            "node": "f61ef94a-6f49-4495-aa2c-9d4e8e3c02fd",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "365dad27-686d-4f38-9bbd-6beeb83573ca": {
      "main": [
        [
          {
            "node": "be3c688c-ca01-42b8-8fd6-6b715a187683",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "7fa5068c-5b7c-4bb5-bd0c-a41560221141": {
      "main": [
        [
          {
            "node": "b9c03922-faf8-4c5c-87ba-cd44b8919aaa",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "da1d59c5-9f44-41b2-9239-9656a5524bc8": {
      "main": [
        [
          {
            "node": "365dad27-686d-4f38-9bbd-6beeb83573ca",
            "type": "main",
            "index": 0
          }
        ]
      ]
    }
  }
}
よくある質問

このワークフローの使い方は?

上記のJSON設定コードをコピーし、n8nインスタンスで新しいワークフローを作成して「JSONからインポート」を選択、設定を貼り付けて認証情報を必要に応じて変更してください。

このワークフローはどんな場面に適していますか?

中級 - 人事

有料ですか?

このワークフローは完全無料です。ただし、ワークフローで使用するサードパーティサービス(OpenAI APIなど)は別途料金が発生する場合があります。

ワークフロー情報
難易度
中級
ノード数14
カテゴリー1
ノードタイプ9
難易度説明

経験者向け、6-15ノードの中程度の複雑さのワークフロー

外部リンク
n8n.ioで表示

このワークフローを共有

カテゴリー

カテゴリー: 34