A clean, Pythonic client for the Canada Post AddressComplete API. Simplify address autocomplete and validation in your applications with type-safe error handling and an intuitive interface.
pip install addresscompletefrom addresscomplete import AddressComplete
client = AddressComplete("your-api-key-here")
results = client.find("123 Main St, Toronto")- Fast Address Search - Get instant address suggestions with customizable parameters
- Detailed Address Retrieval - Fetch complete address information using unique IDs
- Robust Error Handling - Specific exception types for every API error scenario
- Zero Configuration - Works out of the box with sensible defaults
pip install addresscompleteOr install from source:
git clone https://github.com/darianelwood/AddressComplete.git
cd AddressComplete
pip install .Requirements: Python 3.7+ and the requests library (installed automatically).
Get your free API key from Canada Post AddressComplete, then start using the library immediately.
from addresscomplete import AddressComplete
# Initialize the client with your API key
client = AddressComplete("your-api-key-here")
# Search for addresses
results = client.find("123 Main St, Toronto")
print(results)
# Retrieve detailed address information
address_id = "CA|CP|ENG|3X1-R2J"
details = client.retrieve(address_id)
print(details)from addresscomplete import AddressComplete, FindError, RetrieveError
client = AddressComplete("your-api-key-here")
try:
# Search with custom parameters
results = client.find(
search_term="123 Main Street",
country="CAN",
max_suggestions=5,
language_preference="en"
)
# Process and enrich results
for item in results.get("Items", []):
print(f"{item.get('Description')} (ID: {item.get('Id')})")
# Retrieve complete address details
try:
details = client.retrieve(item["Id"])
print(f"Complete address: {details}")
except RetrieveError as e:
print(f"Retrieval failed: {e}")
except FindError as e:
print(f"Search error: {e}")Creates a new client instance.
Parameters:
api_key(str): Your Canada Post AddressComplete API key
Searches for address suggestions matching the search term.
Parameters:
search_term(str): The address search termcountry(str, optional): Country code, defaults to"CAN"max_suggestions(int, optional): Maximum results to return, defaults to10language_preference(str, optional): Language code (2 or 4 digits), defaults to"en"
Returns: dict - JSON response with address suggestions
Raises: FindError - When the API returns an error
Fetches complete address details for the given ID.
Parameters:
id(str): Unique address identifier fromfind()results
Returns: dict - Complete address information
Raises: RetrieveError - When the API returns an error
The library maps API error codes to specific exception types, making error handling straightforward and explicit.
FindError- Raised when address search failsRetrieveError- Raised when address retrieval fails
Both exceptions automatically map error codes to specific exception classes (e.g., InvalidSearchTermError, AccountSuspendedError, UnknownKeyError) for granular error handling.
Licensed under the GNU General Public License v3.0 (GPL-3.0). See LICENSE for details.
Pull requests are welcome. For major changes, please open an issue first to discuss what you'd like to change.
Found a bug or have a question? Open an issue on GitHub.
Author: Darian Elwood (dellwood546@gmail.com)