A full-featured Python client for the USPS API
Project description
pyusps - An API library for USPS, written in Python
pyUSPS is a full-featured, type annotated API client written in Python for the USPS APIs.
This library has been developed with the intention of making the USPS APIs simple and accessible to non-coders while allowing experienced coders to utilize all features the API has to offer without the boilerplate.
Features:
- 100% API Coverage. All endpoints and response models.
- Non-coder friendly. 100% annotated for full IDE auto-completion. Clients handle requests and authentication - just plug the right details in and go!
- Fully annotated. This library has a strong focus on type safety and type hinting. Models are declared and parsed using Pydantic
pyUSPS is currently in development.
Known Issues:
- As this project is still a WIP, documentation or code commentary may not always align.
Road Map:
How-to:
- Install
- Initializing the API Client
- Working with Endpoints
- Pagination
- Contributing
- Supporting the project
Install
Open a terminal and run pip install pyusps
Initializing the API Clients
USPS API
from pyusps import USPSAPIClient
# init client
usps_api_client = USPSAPIClient(
# your api private key,
)
Working with Endpoints
Endpoints are 1:1 to what's available for USPS.
For more information, check out the following resources:
Get many
# sends GET request to /company/companies endpoint
companies = usps_api_client.company.companies.get()
Get one
# sends GET request to /company/companies/{id} endpoint
accounts = usps_api_client.accounts.id("abc123").get()
Get with params
# sends GET request to /company/companies with a conditions query string
conditional_company = usps_api_client.company.companies.get(params={
'conditions': 'company/id=250'
})
Pagination
To make working with paginated data easy, Endpoints that implement a GET response with an array also supply a paginated() method. Under the hood this wraps a GET or POST request as required, but does a lot of neat stuff to make working with pages easier.
Working with pagination
# initialize a PaginatedResponse instance for /agents, starting on page 1 with a pageSize of 100
paginated_agents = sat_api_client.agents.paginated(1,100)
# access the data from the current page using the .data field
page_one_data = paginated_agents.data
# if there's a next page, retrieve the next page worth of data
paginated_agents.get_next_page()
# if there's a previous page, retrieve the previous page worth of data
paginated_agents.get_previous_page()
# iterate over all companies on the current page
for agent in paginated_agents:
# ... do things ...
# iterate over all companies in all pages
# this works by yielding every item on the page, then fetching the next page and continuing until there's no data left
for agent in paginated_agents.all():
# ... do things ...
Contributing
Contributions to the project are welcome. If you find any issues or have suggestions for improvement, please feel free to open an issue or submit a pull request.
Supporting the project
:heart:
Inspiration and Stolen Code
The premise behind this came from the pyConnectWise package and I stole most of the code and adapted it to the USPS API endpoints.
How to Build
python -m build python -m twine upload dist/*
Project details
Release history Release notifications | RSS feed
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 pyuspostalservice-0.1.0.tar.gz.
File metadata
- Download URL: pyuspostalservice-0.1.0.tar.gz
- Upload date:
- Size: 31.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d7d5236ee0b4458ef41f2371d751f0ba6bf9792ae279dac4f1d892730d3776a2
|
|
| MD5 |
091954ec59249f1b9c1f66a47d31871e
|
|
| BLAKE2b-256 |
59f2049733ddc00781a3fc0086be8e729ff6aaf2af1bcd35811b517ec74c8da4
|
File details
Details for the file pyuspostalservice-0.1.0-py3-none-any.whl.
File metadata
- Download URL: pyuspostalservice-0.1.0-py3-none-any.whl
- Upload date:
- Size: 51.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
50bf6bafc55d88457aee0e8b7219298e575a753689d7839e854e4d8933b94ad7
|
|
| MD5 |
561256adbbcba274aa9690d2ea293656
|
|
| BLAKE2b-256 |
00c8532e3efde4a50b7bae1d8ec3ad7c0107d58dece54aa81f13aaeb501f67e6
|