> ## Documentation Index
> Fetch the complete documentation index at: https://docs.enrow.io/llms.txt
> Use this file to discover all available pages before exploring further.

# Bulk-Ergebnisse abrufen

> Ergebnisse, Statistiken und Credit-Aufschlüsselung einer Bulk-E-Mail-Suche anhand der Batch-ID abrufen

<Badge color="blue">GET</Badge>

```
https://api.enrow.io/email/find/bulk?id={id}
```

Rufen Sie alle Ergebnisse einer Batch-E-Mail-Suche anhand der Batch-ID ab. Authentifizieren Sie jede Anfrage mit Ihrem [API-Schlüssel](/de/authentication) im `x-api-key`-Header. Die Batch-ID ist die `id`, die zurückgegeben wird, wenn Sie einen Job über den Endpunkt [Bulk-E-Mails finden](/de/api-reference/email-finder/find-bulk) starten.

<Info>
  Mit einem Webhook können Sie den Aufruf dieses GET-Endpunkts überspringen. Siehe [Wie Webhooks funktionieren](/de/how-webhooks-work).
</Info>

## Query-Parameter

<ParamField query="id" type="string" required>
  Die `id`, die von der POST-Anfrage zurückgegeben wurde
</ParamField>

## Antwort

### 200 — Suche abgeschlossen

<ResponseField name="general" type="object">
  Batch-Metadaten

  <Expandable title="Eigenschaften von general">
    <ResponseField name="id" type="string">
      Batch-Bezeichner
    </ResponseField>

    <ResponseField name="status" type="string">
      `completed`, `ongoing` oder `failed`
    </ResponseField>

    <ResponseField name="custom" type="object">
      Benutzerdefinierte Eigenschaften, die in der ursprünglichen Anfrage übergeben und unverändert zurückgegeben werden
    </ResponseField>
  </Expandable>
</ResponseField>

<ResponseField name="stats" type="object">
  Batch-Statistiken

  <Expandable title="Eigenschaften von stats">
    <ResponseField name="finished" type="number">
      Anzahl der abgeschlossenen Suchen
    </ResponseField>

    <ResponseField name="requested" type="number">
      Gesamtzahl der angeforderten Suchen
    </ResponseField>

    <ResponseField name="valid" type="number">
      Anzahl der gefundenen gültigen E-Mails
    </ResponseField>

    <ResponseField name="credits_cost" type="object">
      Credit-Aufschlüsselung. Credits werden für ungültige oder nicht gefundene Ergebnisse erstattet — siehe [Credits & Abrechnung](/de/credits-billing) dazu, wie Belastungen und Erstattungen funktionieren.

      <Expandable title="Eigenschaften von credits_cost">
        <ResponseField name="initial" type="number">
          Ursprünglich berechnete Credits
        </ResponseField>

        <ResponseField name="refunded" type="number">
          Erstattete Credits (für ungültig/nicht gefunden)
        </ResponseField>

        <ResponseField name="final" type="number">
          Endgültige Credit-Kosten
        </ResponseField>
      </Expandable>
    </ResponseField>
  </Expandable>
</ResponseField>

<ResponseField name="results" type="array">
  Array von Suchergebnissen

  <Expandable title="Eigenschaften der Ergebnisse">
    <ResponseField name="index" type="string">
      Position im ursprünglichen Such-Array
    </ResponseField>

    <ResponseField name="qualification" type="string">
      `valid` (E-Mail gefunden) oder `invalid` (E-Mail nicht gefunden). [Warum binär?](/de/status-codes#why-binary)
    </ResponseField>

    <ResponseField name="email" type="string">
      Die ermittelte E-Mail-Adresse (wenn `valid`)
    </ResponseField>

    <ResponseField name="info" type="object">
      Kontaktinformationen: `domain`, `firstname`, `lastname`, `gender`, `companyInfo`. Die Werte von `firstname` und `lastname` werden großgeschrieben. `info` ist nur bei gültigen Ergebnissen vorhanden.
    </ResponseField>

    <ResponseField name="raw_params" type="object">
      Die ursprünglich gesendeten Suchparameter
    </ResponseField>

    <ResponseField name="custom" type="string | object">
      Benutzerdefinierte Daten, die in der ursprünglichen Suche übergeben wurden
    </ResponseField>
  </Expandable>
</ResponseField>

### 200 — Suche läuft noch

Während der Batch läuft, gibt der GET-Endpunkt HTTP `200` mit einem reduzierten Body in der Form `{ general: { id, status: "ongoing" }, stats: { finished, requested } }` zurück.

<ResponseField name="general" type="object">
  `id` und `status: "ongoing"`
</ResponseField>

<ResponseField name="stats" type="object">
  `finished`- und `requested`-Zähler
</ResponseField>

### Fehlerantworten

| Code    | Nachricht                                |
| ------- | ---------------------------------------- |
| **400** | `Could not retrieve bulk search results` |

Siehe [Fehlerbehandlung](/de/error-handling) für die vollständige Liste der Statuscodes und Antwortformate.

<RequestExample>
  ```bash cURL theme={null}
  curl --request GET \
    --url 'https://api.enrow.io/email/find/bulk?id=3d4cb64e-i64d-41e8-a686-736751004a32' \
    --header 'x-api-key: YOUR_API_KEY'
  ```

  ```javascript Node.js theme={null}
  const batchId = '3d4cb64e-i64d-41e8-a686-736751004a32';
  const response = await fetch(`https://api.enrow.io/email/find/bulk?id=${batchId}`, {
    headers: {
      'x-api-key': process.env.ENROW_API_KEY
    }
  });

  const data = await response.json();
  if (data.general.status === 'completed') {
    console.log(`Valid: ${data.stats.valid}/${data.stats.requested}`);
    console.log(data.results);
  }
  ```

  ```python Python theme={null}
  import requests
  import os

  batch_id = "3d4cb64e-i64d-41e8-a686-736751004a32"
  url = f"https://api.enrow.io/email/find/bulk?id={batch_id}"
  headers = {
      "x-api-key": os.getenv("ENROW_API_KEY")
  }

  response = requests.get(url, headers=headers)
  data = response.json()
  if data["general"]["status"] == "completed":
      print(f"Valid: {data['stats']['valid']}/{data['stats']['requested']}")
  ```
</RequestExample>

<ResponseExample>
  ```json Erfolgsantwort theme={null}
  {
    "general": {
      "id": "3d4cb64e-i64d-41e8-a686-736751004a32",
      "status": "completed",
      "custom": "campaign_q2"
    },
    "stats": {
      "finished": 3,
      "requested": 3,
      "valid": 2,
      "credits_cost": {
        "initial": 3,
        "refunded": 1,
        "final": 2
      }
    },
    "results": [
      {
        "index": "0",
        "qualification": "valid",
        "email": "dwight.schrute@dundermifflin.com",
        "info": {
          "domain": "dundermifflin.com",
          "firstname": "Dwight",
          "lastname": "Schrute",
          "companyInfo": {
            "name": "Dunder Mifflin"
          }
        },
        "raw_params": {
          "company_domain": "dundermifflin.com",
          "fullname": "Dwight Schrute"
        },
        "custom": "lead_001"
      },
      {
        "index": "1",
        "qualification": "valid",
        "email": "jim.halpert@dundermifflin.com",
        "info": {
          "domain": "dundermifflin.com",
          "firstname": "Jim",
          "lastname": "Halpert",
          "companyInfo": {
            "name": "Dunder Mifflin"
          }
        },
        "raw_params": {
          "company_domain": "dundermifflin.com",
          "fullname": "Jim Halpert"
        },
        "custom": "lead_002"
      },
      {
        "index": "2",
        "qualification": "invalid",
        "email": null,
        "raw_params": {
          "company_domain": "dundermifflin.com",
          "fullname": "Ryan Howard"
        },
        "custom": "lead_003"
      }
    ]
  }
  ```

  ```json Fehlerantwort theme={null}
  {
    "message": "..."
  }
  ```
</ResponseExample>

## Nächste Schritte

<CardGroup cols={2}>
  <Card title="E-Mails per Bulk finden" icon="layer-group" href="/de/api-reference/email-finder/find-bulk">
    Starten Sie einen neuen Batch mit bis zu 5.000 E-Mail-Suchen.
  </Card>

  <Card title="Webhooks" icon="bell" href="/de/how-webhooks-work">
    Überspringen Sie das Polling und lassen Sie sich benachrichtigen, wenn ein Batch abgeschlossen ist.
  </Card>

  <Card title="Credits & Abrechnung" icon="coins" href="/de/credits-billing">
    Erfahren Sie, wie Credits pro Ergebnis berechnet und erstattet werden.
  </Card>

  <Card title="E-Mails per Bulk verifizieren" icon="circle-check" href="/de/api-reference/email-verifier/verify-bulk">
    Validieren Sie eine Liste von E-Mail-Adressen in einem einzigen Batch.
  </Card>
</CardGroup>
