Behöver ert företag hjälp med att implementera AI? Kontakta oss och få prisoffert här →
AI Skolan
januari 22, 2026

JSearch till Google Sheets: kurerade jobb på ett ställe

Rickard Andersson Partner, Nodenordic.se

Jobbsökande blir snabbt rörigt. Du gör samma sökningar om och om igen, kopierar länkar till ett dokument, tappar bort vad du redan har granskat och får ändå dubbletter.

Den här JSearch Sheets automation riktar sig i första hand till rekryterare och HR-koordinatorer, men den sparar också tid för byråägare som kurerar roller åt kandidater. Du får ett enda, felfritt Google Sheet som uppdaterar sig självt, så att du kan lägga tiden på urval i stället för insamling.

Du får se vad flödet gör, vad du behöver för att köra det och hur logiken håller din jobblista strukturerad och fri från dubbletter.

Så fungerar den här automatiseringen

Här är det kompletta flödet du kommer att sätta upp:

n8n Workflow Template: JSearch till Google Sheets: kurerade jobb på ett ställe

Varför detta spelar roll: jobbkurering blir lätt ett administrativt slit

Att hitta bra roller är inte det svåra. Det svåra är allt runt omkring: köra sökningar, kopiera resultat, rensa kolumner, ta bort dubbletter och försöka komma ihåg vilka roller du redan har granskat. En enda ”snabbsökning” blir ett litet adminprojekt. Sedan gör du om det i morgon eftersom marknaden rörde på sig, din kund ändrade prioriteringar eller en rekryterande chef bad om ”en batch till” i en annan ort. Det är mentalt dränerande och stjäl i tysthet timmar som du kunde lagt på att faktiskt utvärdera kandidater eller kontakta rekryterande team.

Friktionen byggs på. Här brukar det oftast fallera.

  • Du kör om samma söktermer eftersom det inte finns någon pålitlig ”bearbetad”-status någonstans.
  • Kopiera/klistra från jobbsajter skapar inkonsekventa fält, så filtrering på plats eller företag blir ett irritationsmoment.
  • Dubbletter slinker igenom och slösar granskningstid, särskilt när flera i teamet tar fram roller parallellt.
  • Din ”single source of truth” flyttar mellan flikar, mejl och anteckningar, vilket gör rapportering och överlämningar onödigt smärtsamma.

Det du bygger: JSearch-resultat loggas automatiskt till Google Sheets

Det här flödet ger dig ett enkelt operativsystem för jobbkurering. Enligt ett schema du väljer (dagligen är vanligt) kontrollerar n8n ett Google Sheet efter en rollrad markerad ”Pending”, till exempel ”Customer Success Manager” i ”Austin”. Den använder de fälten för att fråga JSearch API, hämtar jobbannonser och tolkar sedan svaret till strukturerade rader som du faktiskt kan filtrera och sortera. Innan något skrivs validerar det posterna så att du inte förorenar ditt ark med tomma eller skräpannonser. Till sist lägger det till de felfria jobben i ditt utdataark och uppdaterar den ursprungliga förfrågeraden från ”Pending” till ”Scraped” så att den inte körs igen. Sätt upp det en gång, så blir ditt kalkylark ett levande jobbflöde.

Flödet börjar med en schemalagd hämtning från ditt ”Job Scraper”-ark. Sedan anropar det JSearch, strukturerar svaret och behåller bara giltiga jobbposter. Resultatet hamnar i ett ”Job Listing”-ark och din indatarad markeras som bearbetad så att du inte jagar dubbletter senare.

Det du bygger

Förväntade resultat

Säg att du kurerar jobb för 5 roller varje vecka. Manuellt ser en typisk cykel ut så här: 10 minuter för att köra sökningen, 15 minuter för att kopiera/klistra och rensa, och 5 minuter för att ta bort dubbletter – alltså cirka 30 minuter per roll (ungefär 2–3 timmar i veckan). Med det här flödet lägger du in 5 ”Pending”-rader en gång, sedan hämtar och loggar den schemalagda körningen resultaten automatiskt; din tid blir granskning, kanske 5 minuter per roll. Det är runt 2 timmar tillbaka varje vecka, utan att du behöver ändra hur du jobbar.

Innan du börjar

  • n8n-instans (testa n8n Cloud gratis)
  • Alternativ för egen drift om du föredrar det (Hostinger fungerar bra)
  • Google Sheets för in- och utdatatabellerna.
  • JSearch API-åtkomst för att hämta jobbannonser programmatiskt.
  • JSearch API-nyckel (hämta den i din JSearch/RapidAPI-dashboard)

Kunskapsnivå: Nybörjare. Du kopplar Google-inloggning, klistrar in en API-nyckel och bekräftar att dina kolumnnamn i arket matchar.

Vill du att någon bygger detta åt dig? Prata med en automationsexpert (gratis 15-minuters konsultation).

Steg för steg

Ett dagligt schema startar allt. n8n kör automatiskt i den takt du ställer in, så du slipper komma ihåg att ”gå och hämta jobb” varje morgon.

Google Sheets ger nästa sökförfrågan. Flödet läser en rad från ditt ”Job Scraper”-ark där status är ”Pending” och hämtar sedan värdena för Position och Location som definierar vad du vill hitta.

JSearch frågas och resultaten struktureras. En HTTP-förfrågan anropar JSearch API, och därefter omvandlar ett kort tolkningssteg svaret till individuella jobbposter. Efter det filtrerar en validering bort tomma eller ogiltiga poster så att bara användbara rader går vidare.

Felfria annonser hamnar i ditt utdataark och indataraden uppdateras. n8n lägger till jobbraderna i ditt ”Job Listing”-ark och uppdaterar sedan den ursprungliga förfrågeraden till ”Scraped” så att den inte behandlas igen.

Du kan enkelt ändra statusvärdena ”Pending/Scraped” så att de passar din interna process, eller utöka vilka fält som skrivs till utdataarket (som lön, remote-flagga eller annons-URL). Se hela implementationsguiden nedan för anpassningsalternativ.

Steg-för-steg-implementeringsguide

Steg 1: konfigurera Schedule Trigger

Ställ in arbetsflödet så att det körs automatiskt varje dag vid den angivna timmen.

  1. Lägg till noden ⏰ Daily Schedule Trigger som start för arbetsflödet.
  2. Ställ in schemaregeln att köras dagligen kl. 9 (noden använder Trigger At Hour med värdet 9).

Steg 2: anslut Google Sheets

Konfigurera källarket för väntande roller och anslut Google Sheets för alla kalkylarksåtgärder.

  1. Öppna 📄 Fetch Pending Role Row och välj arket med namnet Your_Sheet_No i dokumentet med etiketten Job Scraper.
  2. Ställ in filtret för att hitta rader där Status är lika med Pending och aktivera Return First Match.
  3. Credential Required: Anslut era googleSheetsOAuth2Api-autentiseringsuppgifter i 📄 Fetch Pending Role Row.
  4. Credential Required: Anslut era googleSheetsOAuth2Api-autentiseringsuppgifter i 📊 Append Jobs to Sheet och ✅ Update Source Row Status.

⚠️ Vanlig fallgrop: Säkerställ att arknamnen och dokument-ID:n matchar era faktiska Google Sheets. Felaktiga ark-ID:n ger tomma resultat.

Steg 3: konfigurera API-anropet för jobbsökning

Bygg HTTP-begäran som söker efter jobb baserat på rollraden från Google Sheets.

  1. I 🌐 Job Search API Request ställer ni in URL till https://jsearch.p.rapidapi.com/search.
  2. Aktivera Send Query och lägg till parametern query med värdet {{ $json.Position + ' in ' + $json.Location }}.
  3. Ställ in frågeparametrarna page till 1 och num_pages till 1.
  4. Lägg till headern X-RapidAPI-Key med värdet [CONFIGURE_YOUR_API_KEY] och X-RapidAPI-Host som jsearch.p.rapidapi.com.

⚠️ Vanlig fallgrop: Ersätt [CONFIGURE_YOUR_API_KEY] med er riktiga RapidAPI-nyckel, annars misslyckas anropet.

Steg 4: konfigurera bearbetningsnoderna

Tolka API-svaret och filtrera bort ogiltiga jobbposter innan ni skriver till arket.

  1. I 🧠 Parse Job Results Data behåller ni den medföljande JavaScript-koden som mappar jobbdata till fält som title, company och apply_link.
  2. I 🔍 Validate Job Records ställer ni in villkoret att kontrollera att title finns genom att använda {{ $json.title }}.

Steg 5: konfigurera utdata och statusuppdateringar

Lägg till giltiga jobbposter i destinationsarket och uppdatera status för källraden.

  1. I 📊 Append Jobs to Sheet ställer ni in Operation till appendOrUpdate och mappar kolumner:
    Title{{ $json.title }}
    Company{{ $json.company }}
    Location{{ $json.location }}
    Is Remote{{ $json.is_remote }}
    Posted On{{ $json.posted_date }}
    Apply Link{{ $json.apply_link }}
  2. Ställ in Matching Columns till Apply Link för att förhindra dubbla poster.
  3. I ✅ Update Source Row Status ställer ni in Status till Scraped och mappar row_number till {{ $('📄 Fetch Pending Role Row').item.json.row_number }}.
  4. Bekräfta att dokumentet och arket för ✅ Update Source Row Status pekar på Job Scraper och Your_Sheet_No.

⚠️ Vanlig fallgrop: Fältet row_number måste finnas i källarket, annars matchar uppdateringssteget inga rader.

Steg 6: testa och aktivera ert arbetsflöde

Kör ett manuellt test för att verifiera flödet från början till slut och aktivera sedan för daglig automatisering.

  1. Klicka på Execute Workflow för att köra ett manuellt test som startar från ⏰ Daily Schedule Trigger.
  2. Verifiera att 📊 Append Jobs to Sheet lägger till jobbrader och att ✅ Update Source Row Status ändrar källraden till Scraped.
  3. Om arbetsflödet lyckas, växla Active för att aktivera dagliga körningar.
🔒

Lås upp fullständig steg-för-steg-guide

Få den kompletta implementeringsguiden + nedladdningsbar mall

Felsökningstips

  • Google Sheets-inloggningen kan löpa ut eller sakna redigeringsbehörighet. Om tillägg misslyckas, kontrollera det anslutna Google-kontot i n8n Credentials och bekräfta att målarket är delat på rätt sätt.
  • Om du använder Wait-noder eller extern rendering varierar processtiderna. Öka väntetiden om nedströmsnoder fallerar på tomma svar.
  • JSearch API-anrop kan misslyckas på grund av en ogiltig nyckel eller rate limits. Kontrollera HTTP Request-nodens response body och statuskod först, eftersom den oftast säger exakt vad som är fel.

Snabba svar

Hur lång tid tar det att sätta upp den här JSearch Sheets automation?

Cirka 30 minuter om dina Sheets och din API-nyckel är redo.

Krävs det kodning för den här automatiseringen för jobbkurering?

Nej. Du kopplar främst konton och klistrar in din JSearch API-nyckel. Tolkningssteget ingår redan i flödet.

Är n8n gratis att använda för det här JSearch Sheets automation-flödet?

Ja. n8n har ett gratis alternativ för egen drift och en gratis provperiod på n8n Cloud. Cloud-planer börjar på 20 USD/månad för högre volymer. Du behöver också räkna med kostnader för JSearch API beroende på plan och användning.

Var kan jag hosta n8n för att köra den här automatiseringen?

Två alternativ: n8n Cloud (hanterat, enklast att komma igång) eller egen drift på en VPS. För egen drift är Hostinger VPS prisvärt och hanterar n8n bra. Egen drift ger dig obegränsade körningar men kräver grundläggande serverhantering.

Kan jag ändra det här JSearch Sheets automation-flödet för andra användningsfall?

Ja, och det är enkelt. Du kan ändra vilka rader som plockas upp genom att redigera Google Sheets-steget ”Fetch Pending Role Row” (till exempel använda ”Queued” i stället för ”Pending”), och du kan ändra vad som skrivs genom att uppdatera fältmappningen i ”Append Jobs to Sheet”. Vanliga anpassningar är att hämta fler fält (lön, remote/hybrid), lägga till striktare valideringsregler eller ändra schemat till att köra varannan timme.

Varför misslyckas min Google Sheets-anslutning i det här flödet?

Oftast handlar det om behörigheter. Anslut Google Sheets-credentialn igen i n8n och se till att kalkylarket ägs av, eller är delat med, samma Google-konto. Bekräfta också att fliknamnen i arket matchar vad noderna förväntar sig, eftersom en omdöpt flik kan se ut som ett ”saknad fil”-fel.

Vilken volym kan det här JSearch Sheets automation-flödet hantera?

Tillräckligt för de flesta små team. På n8n Cloud beror din gräns på planens månatliga körningar, och varje körning räknas vanligtvis som en körning plus de items som behandlas. Om du kör egen drift finns inget plattforms-tak för körningar; din server och JSearch API-begränsningar blir flaskhalsen. I praktiken, om du kurerar några roller per dag med en eller två sidor resultat per roll, så går det utan problem.

Är den här JSearch Sheets automation bättre än att använda Zapier eller Make?

Ofta, ja, eftersom det här flödet behöver tolkning, filtrering och statusuppdateringar som är krångliga (och ibland dyra) i enklare automationsverktyg. n8n hanterar flersteglogik snyggt, och du kan köra egen drift med obegränsade körningar om volymen ökar. Zapier eller Make kan fortfarande fungera om du bara vill ha en enkel ”API-anrop → lägg till rader”-setup med minimal datarensning. Så fort du bryr dig om validering och att undvika att bearbeta samma förfrågerad igen brukar n8n kännas mindre skört. Vill du ha en snabb rekommendation baserat på din volym och ditt team, prata med en automationsexpert.

När dina sökningar automatiskt flödar in i ett felfritt ark slutar jobbkurering kännas som en daglig omstart. Du granskar bättre roller snabbare, och flödet sköter de repetitiva delarna i bakgrunden.

Kontakta oss

Hör av dig, så diskuterar vi hur just din verksamhet kan dra nytta av alla fantastiska möjligheter som AI skapar.

×

Använd mall

Få direkt tillgång till denna n8n-arbetsflödes JSON-fil

Få prisoffert redan idag!
Få prisoffert redan idag!

Berätta vad ni behöver hjälp med så hör vi av oss inom en arbetsdag!

Få prisoffert redan idag!
Få prisoffert redan idag!

Berätta vad ni behöver hjälp med så hör vi av oss inom en arbetsdag!

Launch login modal Launch register modal