# US Tariff & HTS Code Scraper (`lulzasaur/tariff-hts-scraper`) Actor

Search US Harmonized Tariff Schedule codes by keyword, look up specific HTS codes for duty rates, and get recent tariff changes from USITC.

- **URL**: https://apify.com/lulzasaur/tariff-hts-scraper.md
- **Developed by:** [lulz bot](https://apify.com/lulzasaur) (community)
- **Categories:** E-commerce
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

Pay per usage

This Actor is paid per platform usage. The Actor is free to use, and you only pay for the Apify platform usage, which gets cheaper the higher subscription plan you have.

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

## 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 Tariff & HTS Code Scraper

Search, look up, and track US tariff codes and duty rates from the official USITC Harmonized Tariff Schedule. Get structured data on HTS codes, duty rates, free trade agreement programs, and recent tariff changes including Section 301 and Section 232 modifications.

### Features

- **Search by keyword** -- Find HTS codes for any product (e.g., "steel", "electronics", "automobile parts")
- **Look up specific HTS codes** -- Get full details for any tariff line item including duty rates and hierarchy
- **Track tariff changes** -- Monitor recent notices, schedule releases, and hot-topic tariff areas (Section 301, 232, IEEPA)
- **FTA program decoding** -- Automatically maps special duty program codes (A, AU, CA, KR, etc.) to full trade agreement names
- **Hierarchical context** -- Enriches results with chapter, heading, and subheading descriptions
- **Supplementary tariff documents** -- Detects China Tariff annexes and other supplementary files

### Input Parameters

| Parameter | Type | Default | Description |
|-----------|------|---------|-------------|
| `mode` | string | `"search"` | Operation mode: `search`, `lookup`, or `changes` |
| `searchTerm` | string | `""` | Keyword to search for HTS codes (used in `search` mode) |
| `htsCode` | string | `""` | Specific HTS code to look up, e.g. `"7206.10.0000"` (used in `lookup` mode) |
| `maxResults` | integer | `100` | Maximum number of results to return (1-500) |
| `includeParentCodes` | boolean | `true` | Include parent heading/subheading codes that show hierarchy |
| `proxyConfiguration` | object | -- | Optional proxy configuration |

### Example Inputs

**Search for steel tariff codes:**
```json
{
  "mode": "search",
  "searchTerm": "steel pipe",
  "maxResults": 50
}
````

**Look up a specific HTS code:**

```json
{
  "mode": "lookup",
  "htsCode": "7206.10.0000"
}
```

**Get recent tariff changes and notices:**

```json
{
  "mode": "changes"
}
```

### Output Fields

#### Search / Lookup Results

| Field | Type | Description |
|-------|------|-------------|
| `htsCode` | string | The HTS tariff code number |
| `description` | string | Official tariff description |
| `generalDutyRate` | string | General (MFN) duty rate |
| `specialDutyRate` | string | Special duty rate string with FTA program codes |
| `specialPrograms` | array | Parsed FTA programs with rates and program codes |
| `specialProgramDetails` | array | FTA programs with full human-readable names (lookup mode) |
| `otherDutyRate` | string | Column 2 (non-NTR) duty rate |
| `units` | string | Unit of quantity |
| `indent` | number | Hierarchy indent level |
| `isLineItem` | boolean | Whether this is a dutiable line item vs. a heading |
| `statisticalSuffix` | string | Statistical reporting suffix |
| `additionalDuties` | array | Footnote references (Section 301, 232, etc.) |
| `chapterDescription` | string | Parent chapter description (lookup mode) |
| `headingDescription` | string | Parent 4-digit heading description (lookup mode) |
| `subheadingDescription` | string | Parent 6-digit subheading description (lookup mode) |

#### Changes Results

| Field | Type | Description |
|-------|------|-------------|
| `type` | string | `notice`, `release`, `supplementary_tariff`, or `tariff_area` |
| `title` | string | Title or label of the change |
| `description` | string | Description or content of the notice |
| `matchCount` | number | Number of related HTS entries (for tariff areas) |
| `sampleCodes` | array | Sample affected HTS codes with duty rates |

### Use Cases

- **Import/export compliance** -- Look up duty rates before shipping goods
- **Trade policy monitoring** -- Track Section 301 China tariffs, Section 232 steel/aluminum duties
- **Cost estimation** -- Calculate landed cost by finding applicable duty rates and FTA eligibility
- **Supply chain analysis** -- Identify tariff-free options through free trade agreement programs
- **Regulatory research** -- Stay current on USITC schedule releases and tariff modifications

### Data Source

All data is sourced from the official [USITC Harmonized Tariff Schedule](https://hts.usitc.gov/) REST API.

***

### Run on Apify

This scraper runs on the [Apify platform](https://apify.com/?fpr=lulzasaur) -- a full-stack web scraping and automation cloud. Sign up for a free account to get started with 30-day trial of all features.

[Try Apify free ->](https://apify.com/?fpr=lulzasaur)

# Actor input Schema

## `mode` (type: `string`):

Operation mode: 'search' to find HTS codes by keyword, 'lookup' to get details for a specific HTS code, 'changes' to get recent tariff modifications.

## `searchTerm` (type: `string`):

Keyword to search for HTS codes (e.g. 'steel', 'electronics', 'automobile parts'). Used in 'search' mode.

## `htsCode` (type: `string`):

Specific HTS code to look up (e.g. '7206.10.0000', '8471', '0901.21'). Used in 'lookup' mode.

## `maxResults` (type: `integer`):

Maximum number of results to return (USITC API returns up to 100 per search). Default 100.

## `includeParentCodes` (type: `boolean`):

Include parent heading/subheading codes in results (codes without duty rates that show hierarchy). Default true.

## `proxyConfiguration` (type: `object`):

Optional proxy to use.

## Actor input object example

```json
{
  "mode": "search",
  "searchTerm": "",
  "htsCode": "",
  "maxResults": 100,
  "includeParentCodes": true
}
```

# 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("lulzasaur/tariff-hts-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("lulzasaur/tariff-hts-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 lulzasaur/tariff-hts-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "US Tariff & HTS Code Scraper",
        "description": "Search US Harmonized Tariff Schedule codes by keyword, look up specific HTS codes for duty rates, and get recent tariff changes from USITC.",
        "version": "1.0",
        "x-build-id": "FiNK0JgDNygHCQdgv"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/lulzasaur~tariff-hts-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-lulzasaur-tariff-hts-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/lulzasaur~tariff-hts-scraper/runs": {
            "post": {
                "operationId": "runs-sync-lulzasaur-tariff-hts-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/lulzasaur~tariff-hts-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-lulzasaur-tariff-hts-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": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "search",
                            "lookup",
                            "changes"
                        ],
                        "type": "string",
                        "description": "Operation mode: 'search' to find HTS codes by keyword, 'lookup' to get details for a specific HTS code, 'changes' to get recent tariff modifications.",
                        "default": "search"
                    },
                    "searchTerm": {
                        "title": "Search Term",
                        "type": "string",
                        "description": "Keyword to search for HTS codes (e.g. 'steel', 'electronics', 'automobile parts'). Used in 'search' mode.",
                        "default": ""
                    },
                    "htsCode": {
                        "title": "HTS Code",
                        "type": "string",
                        "description": "Specific HTS code to look up (e.g. '7206.10.0000', '8471', '0901.21'). Used in 'lookup' mode.",
                        "default": ""
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 500,
                        "type": "integer",
                        "description": "Maximum number of results to return (USITC API returns up to 100 per search). Default 100.",
                        "default": 100
                    },
                    "includeParentCodes": {
                        "title": "Include Parent Codes",
                        "type": "boolean",
                        "description": "Include parent heading/subheading codes in results (codes without duty rates that show hierarchy). Default true.",
                        "default": true
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Optional proxy to use."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
