Harmonized System (HS) codes from the World Customs Organization with hierarchical structure and search capabilities
Project description
pyhscodes
A Python package for working with Harmonized System (HS) codes from the World Customs Organization. Built on the foundation of the popular pycountry package, pyhscodes provides a similar API for HS codes with hierarchical structure and search capabilities.
Features
- Complete HS Code Database: Contains 6,940+ HS codes with full hierarchical structure
- Section Support: All 21 HS code sections with descriptions
- Hierarchical Navigation: Navigate from chapters (2-digit) to headings (4-digit) to subheadings (6-digit)
- Fuzzy Search: Find codes by description text
- Fast Lookups: Optimized indexing for quick code retrieval
- Pythonic API: Clean, intuitive interface similar to pycountry
Installation
pip install pyhscodes
Quick Start
import pyhscodes
# Basic statistics
print(f"Total HS codes: {len(pyhscodes.hscodes)}")
print(f"Total sections: {len(pyhscodes.sections)}")
# Get a specific code
animals = pyhscodes.hscodes.get(hscode="01")
print(f"{animals.hscode}: {animals.description}")
# Get children of a code
children = pyhscodes.hscodes.get_children("01")
for child in children:
print(f" {child.hscode}: {child.description}")
# Get full hierarchy
hierarchy = pyhscodes.hscodes.get_hierarchy("010121")
for code in hierarchy:
print(f"{code.hscode}: {code.description} (Level {code.level})")
# Fuzzy search
results = pyhscodes.hscodes.search_fuzzy("dairy")
for result in results[:3]:
print(f"{result.hscode}: {result.description}")
API Reference
HS Codes
pyhscodes.hscodes
The main database of HS codes.
Properties:
hscode: The HS code (e.g., "010121")description: Description of the codesection: Which section this code belongs toparent: Parent code in the hierarchylevel: Code level ("2", "4", or "6")EUDR: Boolean indicating EU Deforestation Regulation applicabilityEUTR: Boolean indicating EU Timber Regulation applicabilityCBAM: Boolean indicating Carbon Border Adjustment Mechanism applicabilityis_chapter: True if this is a 2-digit chapteris_heading: True if this is a 4-digit headingis_subheading: True if this is a 6-digit subheading
Methods:
get(hscode="01"): Get a specific codelookup("01"): Lookup by code or descriptionsearch_fuzzy("horses"): Fuzzy search by descriptionget_by_level("2"): Get all codes at a specific levelget_children("01"): Get child codesget_hierarchy("010121"): Get full hierarchy path
Sections
pyhscodes.sections
Database of HS code sections.
Properties:
section: Section identifier (e.g., "I", "II")name: Section name/description
Methods:
get(section="I"): Get a specific section
Data Structure
HS codes follow a hierarchical structure:
- Sections: 21 major groupings (I through XXI)
- Chapters: 97 two-digit codes (01, 02, ..., 97)
- Headings: 1,229+ four-digit codes (0101, 0102, ...)
- Subheadings: 5,613+ six-digit codes (010121, 010122, ...)
Example hierarchy:
Section I: Live animals; animal products
├── 01: Animals; live
├── 0101: Horses, asses, mules and hinnies; live
├── 010121: Horses; live, pure-bred breeding animals
└── 010129: Horses; live, other than pure-bred breeding animals
Examples
See example.py for a comprehensive demonstration of the package features.
Development
Setting up for development
git clone https://github.com/yourusername/pyhscodes.git
cd pyhscodes
pip install -e .
Running tests
pytest src/pyhscodes/tests/
Data Updates
To update the HS codes database:
-
Place your CSV files in the project root:
harmonized-system-with-standards.csv(columns: section, hscode, description, parent, level, EUDR, EUTR, CBAM)sections.csv(columns: section, name)
-
Run the conversion script:
python convert_csv_to_json.py
Changelog
2.0.0 (Breaking Change)
- Added regulatory standard flags: Each HS code now includes boolean fields for EU regulatory standards:
EUDR: EU Deforestation Regulation applicabilityEUTR: EU Timber Regulation applicabilityCBAM: Carbon Border Adjustment Mechanism applicability
- Data source changed: Now uses
harmonized-system-with-standards.csvinstead ofharmonized-system.csv - Breaking: HS code entries now have additional fields that may affect serialization or data processing
1.0.x
- Initial release with core HS code database
- Hierarchical navigation and fuzzy search
- Section support
License
This project is licensed under the LGPL-2.1 License - see the LICENSE file for details.
Acknowledgments
- Built on the foundation of pycountry
- HS codes from the World Customs Organization
- Inspired by the need for a Python package similar to pycountry but for trade classification codes
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyhscodes-2.0.0.tar.gz.
File metadata
- Download URL: pyhscodes-2.0.0.tar.gz
- Upload date:
- Size: 178.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b11225ff98c220c26765d14c706521fbf080362725e02df232e046502660b65
|
|
| MD5 |
c7baaa79e73cca6c46d5bd956a016cb4
|
|
| BLAKE2b-256 |
ed650af7e424d76fbf5624a062f419751134a79fd098886bfd19b6c05f0eff82
|
File details
Details for the file pyhscodes-2.0.0-py3-none-any.whl.
File metadata
- Download URL: pyhscodes-2.0.0-py3-none-any.whl
- Upload date:
- Size: 185.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6769377db44c01e869bd0bc0e65bed2da420c7fbc23deb082a715b3eafc00af9
|
|
| MD5 |
afd762d4059c1a57cb10525aaf7896e2
|
|
| BLAKE2b-256 |
1ef7a2a9b856b47ce5a21f5f424447089d397506e84e87a2a46a9c2a3a24d085
|