# TimeZoneAdapter
A Python library that provides an easy-to-use interface for converting and manipulating datetime objects across different time zones.
[![PyPI version](https://badge.fury.io/py/timezone-adapter.svg)](https://badge.fury.io/py/timezone-adapter)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Python Versions](https://img.shields.io/pypi/pyversions/timezone-adapter.svg)](https://pypi.org/project/timezone-adapter/)
## Features
- Convert between time zones using numeric offset or timezone name
- Convert to and from UTC
- Calculate minimum and maximum dates for a specific day
- Support for both timezone offsets and timezone names (e.g., 'America/Bogota')
- Type hints support
- Zero dependencies (except pytz)
## Installation
```bash
pip install timezone-adapter
```
## Quick Start
```python
from datetime import datetime
from timezone_adapter import TimeZoneAdapter
# Using numeric offset (hours)
tz_adapter = TimeZoneAdapter(-5) # UTC-5
# Using timezone name
tz_adapter = TimeZoneAdapter('America/Bogota')
# Convert to UTC
local_time = datetime.now()
utc_time = tz_adapter.to_utc(local_time)
# Get range of dates for today
min_date, max_date = tz_adapter.get_min_max_datetime_today()
```
## API Reference
### TimeZoneAdapter
#### `__init__(timezone: Union[int, str])`
Initialize with either a numeric offset (hours from UTC) or timezone name.
#### `to_utc(date_time: datetime) -> datetime`
Convert a local datetime to UTC.
#### `from_utc(date_time: datetime) -> datetime`
Convert a UTC datetime to local time.
#### `get_min_max_datetime_today() -> Tuple[datetime, datetime]`
Get the minimum and maximum datetime for the current day.
#### `get_min_max_datetime_by_date(date_time: datetime) -> Tuple[datetime, datetime]`
Get the minimum and maximum datetime for a specific date.
## Development
### Setup Development Environment
Clone the repository
```bash
git clone https://github.com/miguepoloc/timezone-adapter.git
cd timezone-adapter
```
Create and activate virtual environment
```bash
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
```
Install development dependencies
```bash
pip install -e ".[dev]"
```
Run tests
```bash
pytest
```
### Code Quality
We use several tools to ensure code quality:
- `black` for code formatting
- `isort` for import sorting
- `mypy` for type checking
- `flake8` for style guide enforcement
Run all checks with:
```bash
pre-commit run --all-files
```
## Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
1. Fork the repository
2. Create your feature branch (`git checkout -b feature/AmazingFeature`)
3. Commit your changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request
## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
## Author
Miguel Angel Polo Castañeda - [@miguepoloc](https://github.com/miguepoloc)
## Acknowledgments
- Thanks to the `pytz` library for timezone support
- Inspired by the need for simpler timezone handling in Python
Raw data
{
"_id": null,
"home_page": "https://github.com/miguepoloc/timezone-adapter",
"name": "timezone-adapter",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.6",
"maintainer_email": null,
"keywords": "timezone, datetime, converter",
"author": "Miguel Angel Polo Casta\u00f1eda",
"author_email": "Miguel Angel Polo Casta\u00f1eda <miguepoloc@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/99/9b/4740784ecf368789b9deb9f537981f5fd174311a7f6c56add93439223a63/timezone_adapter-0.1.1.tar.gz",
"platform": null,
"description": "# TimeZoneAdapter\n\nA Python library that provides an easy-to-use interface for converting and manipulating datetime objects across different time zones.\n\n[![PyPI version](https://badge.fury.io/py/timezone-adapter.svg)](https://badge.fury.io/py/timezone-adapter)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n[![Python Versions](https://img.shields.io/pypi/pyversions/timezone-adapter.svg)](https://pypi.org/project/timezone-adapter/)\n\n## Features\n\n- Convert between time zones using numeric offset or timezone name\n- Convert to and from UTC\n- Calculate minimum and maximum dates for a specific day\n- Support for both timezone offsets and timezone names (e.g., 'America/Bogota')\n- Type hints support\n- Zero dependencies (except pytz)\n\n## Installation\n```bash\npip install timezone-adapter\n```\n\n## Quick Start\n\n```python\nfrom datetime import datetime\nfrom timezone_adapter import TimeZoneAdapter\n\n# Using numeric offset (hours)\ntz_adapter = TimeZoneAdapter(-5) # UTC-5\n\n# Using timezone name\ntz_adapter = TimeZoneAdapter('America/Bogota')\n\n# Convert to UTC\nlocal_time = datetime.now()\nutc_time = tz_adapter.to_utc(local_time)\n\n# Get range of dates for today\nmin_date, max_date = tz_adapter.get_min_max_datetime_today()\n```\n\n## API Reference\n\n### TimeZoneAdapter\n\n#### `__init__(timezone: Union[int, str])`\nInitialize with either a numeric offset (hours from UTC) or timezone name.\n\n#### `to_utc(date_time: datetime) -> datetime`\nConvert a local datetime to UTC.\n\n#### `from_utc(date_time: datetime) -> datetime`\nConvert a UTC datetime to local time.\n\n#### `get_min_max_datetime_today() -> Tuple[datetime, datetime]`\nGet the minimum and maximum datetime for the current day.\n\n#### `get_min_max_datetime_by_date(date_time: datetime) -> Tuple[datetime, datetime]`\nGet the minimum and maximum datetime for a specific date.\n\n## Development\n\n### Setup Development Environment\n\nClone the repository\n\n```bash\ngit clone https://github.com/miguepoloc/timezone-adapter.git\ncd timezone-adapter\n```\n\nCreate and activate virtual environment\n\n```bash\npython -m venv .venv\nsource .venv/bin/activate # On Windows: .venv\\Scripts\\activate\n```\n\nInstall development dependencies\n\n```bash\npip install -e \".[dev]\"\n```\n\nRun tests\n\n```bash\npytest\n```\n\n\n### Code Quality\n\nWe use several tools to ensure code quality:\n\n- `black` for code formatting\n- `isort` for import sorting\n- `mypy` for type checking\n- `flake8` for style guide enforcement\n\nRun all checks with:\n\n```bash\npre-commit run --all-files\n```\n\n\n## Contributing\n\nContributions are welcome! Please feel free to submit a Pull Request.\n\n1. Fork the repository\n2. Create your feature branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n## License\n\nThis project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.\n\n## Author\n\nMiguel Angel Polo Casta\u00f1eda - [@miguepoloc](https://github.com/miguepoloc)\n\n## Acknowledgments\n\n- Thanks to the `pytz` library for timezone support\n- Inspired by the need for simpler timezone handling in Python\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A class for converting and manipulating datetime objects based on given timezone offset or name.",
"version": "0.1.1",
"project_urls": {
"Homepage": "https://github.com/miguepoloc/timezone-adapter",
"Repository": "https://github.com/miguepoloc/timezone-adapter.git"
},
"split_keywords": [
"timezone",
" datetime",
" converter"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "962dfbe4f0d48965e43db52192e42229c811075d4aea8ab7bf3bad848e0aeec6",
"md5": "077fb8a21a480ac91033ff8a831055cd",
"sha256": "c078b67dc7ec3aa403bbf73740547727c56db32c752c62afe31d1260e9254c7b"
},
"downloads": -1,
"filename": "timezone_adapter-0.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "077fb8a21a480ac91033ff8a831055cd",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.6",
"size": 5113,
"upload_time": "2025-01-14T23:04:47",
"upload_time_iso_8601": "2025-01-14T23:04:47.169041Z",
"url": "https://files.pythonhosted.org/packages/96/2d/fbe4f0d48965e43db52192e42229c811075d4aea8ab7bf3bad848e0aeec6/timezone_adapter-0.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "999b4740784ecf368789b9deb9f537981f5fd174311a7f6c56add93439223a63",
"md5": "9e8858f110f245a615f220d78e528501",
"sha256": "383d50de8364ed5a6aea2d36a7ead8e91c0bb7f079bc4a1d028a678fdb668bb9"
},
"downloads": -1,
"filename": "timezone_adapter-0.1.1.tar.gz",
"has_sig": false,
"md5_digest": "9e8858f110f245a615f220d78e528501",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.6",
"size": 5106,
"upload_time": "2025-01-14T23:04:48",
"upload_time_iso_8601": "2025-01-14T23:04:48.544620Z",
"url": "https://files.pythonhosted.org/packages/99/9b/4740784ecf368789b9deb9f537981f5fd174311a7f6c56add93439223a63/timezone_adapter-0.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-14 23:04:48",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "miguepoloc",
"github_project": "timezone-adapter",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [],
"lcname": "timezone-adapter"
}