# US Federal Contracts & Spending Scraper (USAspending) (`foo121/usaspending-scraper`) Actor

Export US federal awards, contracts and grants by keyword, recipient, agency and date from USAspending.gov. Govcon competitive intelligence, pay per result.

- **URL**: https://apify.com/foo121/usaspending-scraper.md
- **Developed by:** [ziv shay](https://apify.com/foo121) (community)
- **Categories:** Business, Lead generation
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

$5.00 / 1,000 result items

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## US Federal Contracts & Spending Scraper (USAspending)

**The federal contracts scraper that pulls live USAspending data — award amounts, recipients, agencies, and descriptions — straight from the official USAspending.gov API, sorted biggest awards first.**

Built for govcon competitive intelligence and BD/capture teams who need fast, structured government contract data without paying for an enterprise seat. Also used by journalists and researchers tracking where federal dollars go. Search by keyword, recipient (e.g. "Lockheed Martin"), award type, and date range.

Data comes from the **official USAspending.gov API** — **no API key required**. Coverage runs back to **2007-10-01**, and results are **sorted by award amount descending** so the biggest awards land at the top of your dataset.

### What you get

| Field | Description |
|-------|-------------|
| `awardId` | Unique award identifier (PIID / FAIN / URI) |
| `recipient` | Name of the company or entity that received the award |
| `amount` | Award amount in USD (number) |
| `agency` | Awarding federal agency |
| `awardType` | Human-readable award label (e.g. "Definitive Contract") |
| `startDate` | Period of performance start date |
| `endDate` | Period of performance end / current end date |
| `description` | Award description text |
| `url` | Link to the award detail page on USAspending.gov |

### Input

| Field | Type | Default | Description |
|-------|------|---------|-------------|
| `keywords` | array | `[]` | Free-text keywords to match against award data |
| `recipientName` | string | _(optional)_ | Filter by recipient, e.g. "Lockheed Martin" |
| `awardTypeCodes` | array | `["A","B","C","D"]` | Award types. Contracts `A`-`D`; IDVs `IDV_A`..`IDV_E`; grants `02`-`11` |
| `startDate` | string (YYYY-MM-DD) | `"2025-01-01"` | Earliest award action date |
| `endDate` | string (YYYY-MM-DD) | today | Latest award action date |
| `maxItems` | integer | `500` | Maximum number of awards to return |

#### Example input

```json
{
  "keywords": ["cybersecurity"],
  "recipientName": "Lockheed Martin",
  "awardTypeCodes": ["A", "B", "C", "D"],
  "startDate": "2024-01-01",
  "endDate": "2025-06-01",
  "maxItems": 500
}
````

### Example run output

```json
{
  "awardId": "FA875024C0123",
  "recipient": "LOCKHEED MARTIN CORPORATION",
  "amount": 482350000,
  "agency": "Department of Defense",
  "awardType": "Definitive Contract",
  "startDate": "2024-03-15",
  "endDate": "2029-03-14",
  "description": "F-35 SUSTAINMENT AND CYBERSECURITY MODERNIZATION SERVICES",
  "url": "https://www.usaspending.gov/award/CONT_AWD_FA875024C0123"
}
```

### Use cases

- **Govcon competitive intelligence** — track competitors' new awards, agency wins, and contract values to size markets and time recompetes.
- **BD / capture teams** — find who is winning the contracts you chase, by agency and keyword, before the bid cycle.
- **Journalists & watchdogs** — follow the money on federal spending and surface the biggest awards by recipient or program.
- **Researchers & analysts** — build government contract data sets for funding, procurement, or policy analysis.

### vs GovWin IQ and other govcon-intel platforms

Seat-licensed govcon-intelligence platforms like GovWin IQ run **$12,000–$42,000/yr per seat**. This scraper pulls the **same underlying official award data** from USAspending.gov on a pay-per-result basis with no seat license.

**Honest caveat:** this returns raw federal award data, not the analyst layer (forecasts, teaming, opportunity scoring) that platforms like GovWin add on top. If you want the structured government contract data feed, this is the cheap, direct path; if you need the human-curated intel layer, this complements rather than replaces it.

### Pricing

Pay per result — you are billed only for the federal contract records returned to your dataset.

### Keywords

federal contracts scraper, USAspending data, USAspending.gov API, government contract data, federal spending scraper, govcon competitive intelligence, federal award data, contract awards by recipient, defense contract scraper, federal procurement data

# Actor input Schema

## `keywords` (type: `array`):

Free-text keywords to search award descriptions/recipients (e.g. "cybersecurity", "cloud migration"). Optional. Leave empty to pull all awards in the window.

## `recipientName` (type: `string`):

Filter to a specific contractor / recipient (e.g. "Lockheed Martin", "Booz Allen"). Optional.

## `awardTypeCodes` (type: `array`):

USAspending award type codes. Contracts: A,B,C,D. IDVs: IDV\_A..IDV\_E. Grants/assistance: 02-11. Default = contracts (A,B,C,D).

## `startDate` (type: `string`):

Earliest award action date (YYYY-MM-DD). USAspending data goes back to 2007-10-01 for search.

## `endDate` (type: `string`):

Latest award action date (YYYY-MM-DD). Defaults to today.

## `maxItems` (type: `integer`):

Maximum number of award records to output.

## Actor input object example

```json
{
  "keywords": [],
  "awardTypeCodes": [
    "A",
    "B",
    "C",
    "D"
  ],
  "startDate": "2025-01-01",
  "endDate": "2026-06-20",
  "maxItems": 500
}
```

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {};

// Run the Actor and wait for it to finish
const run = await client.actor("foo121/usaspending-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {}

# Run the Actor and wait for it to finish
run = client.actor("foo121/usaspending-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{}' |
apify call foo121/usaspending-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=foo121/usaspending-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "US Federal Contracts & Spending Scraper (USAspending)",
        "description": "Export US federal awards, contracts and grants by keyword, recipient, agency and date from USAspending.gov. Govcon competitive intelligence, pay per result.",
        "version": "1.0",
        "x-build-id": "Bf1r4BcQaabbnQOO9"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/foo121~usaspending-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-foo121-usaspending-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/foo121~usaspending-scraper/runs": {
            "post": {
                "operationId": "runs-sync-foo121-usaspending-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/foo121~usaspending-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-foo121-usaspending-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "properties": {
                    "keywords": {
                        "title": "Keywords",
                        "type": "array",
                        "description": "Free-text keywords to search award descriptions/recipients (e.g. \"cybersecurity\", \"cloud migration\"). Optional. Leave empty to pull all awards in the window.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "recipientName": {
                        "title": "Recipient name",
                        "type": "string",
                        "description": "Filter to a specific contractor / recipient (e.g. \"Lockheed Martin\", \"Booz Allen\"). Optional."
                    },
                    "awardTypeCodes": {
                        "title": "Award type codes",
                        "type": "array",
                        "description": "USAspending award type codes. Contracts: A,B,C,D. IDVs: IDV_A..IDV_E. Grants/assistance: 02-11. Default = contracts (A,B,C,D).",
                        "default": [
                            "A",
                            "B",
                            "C",
                            "D"
                        ],
                        "items": {
                            "type": "string"
                        }
                    },
                    "startDate": {
                        "title": "Start date",
                        "type": "string",
                        "description": "Earliest award action date (YYYY-MM-DD). USAspending data goes back to 2007-10-01 for search.",
                        "default": "2025-01-01"
                    },
                    "endDate": {
                        "title": "End date",
                        "type": "string",
                        "description": "Latest award action date (YYYY-MM-DD). Defaults to today.",
                        "default": "2026-06-20"
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 100000,
                        "type": "integer",
                        "description": "Maximum number of award records to output.",
                        "default": 500
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
