.. image:: https://raw.githubusercontent.com/alexprengere/currencyconverter/master/logo/cc3.png
|actions|_ |cratev|_ |crated|_
.. _actions : https://github.com/alexprengere/currencyconverter/actions/workflows/python-package.yml
.. |actions| image:: https://github.com/alexprengere/currencyconverter/actions/workflows/python-package.yml/badge.svg
.. _cratev : https://pypi.org/project/CurrencyConverter/
.. |cratev| image:: https://img.shields.io/pypi/v/currencyconverter.svg
.. _crated : https://pypi.org/project/CurrencyConverter/
.. |crated| image:: https://static.pepy.tech/badge/currencyconverter
This is a currency converter that uses historical rates against a reference currency (Euro). It is compatible with Python3.9+.
Currency data sources
---------------------
The default source is the `European Central Bank <https://www.ecb.europa.eu>`_. This is the ECB historical rates for 42 currencies against the Euro since 1999.
It can be downloaded here: `eurofxref-hist.zip <https://www.ecb.europa.eu/stats/eurofxref/eurofxref-hist.zip>`_.
The converter can use different sources as long as the format is the same.
Note that the currency converter does not query the API in real time, to avoid the overhead of the HTTP request. It uses embedded data in the library, which might not be up to date.
If you need the latest data, please refer to the *data* section.
Installation
------------
You can install directly after cloning:
.. code-block:: bash
$ python setup.py install --user
Or use the Python package:
.. code-block:: bash
$ pip install --user currencyconverter
Command line tool
-----------------
After installation, you should have ``currency_converter`` in your ``$PATH``:
.. code-block:: bash
$ currency_converter 100 USD --to EUR
100.000 USD = 87.512 EUR on 2016-05-06
Python API
----------
Create once the currency converter object:
.. code-block:: python
>>> from currency_converter import CurrencyConverter
>>> c = CurrencyConverter()
Convert from ``EUR`` to ``USD`` using the last available rate:
.. code-block:: python
>>> c.convert(100, 'EUR', 'USD') # doctest: +SKIP
137.5...
Default target currency is ``EUR``:
.. code-block:: python
>>> c.convert(100, 'EUR')
100.0
>>> c.convert(100, 'USD') # doctest: +SKIP
72.67...
You can change the date of the rate:
.. code-block:: python
>>> from datetime import date # datetime works too
>>> c.convert(100, 'EUR', 'USD', date=date(2013, 3, 21))
129...
Data
~~~~
You can use your own currency file, as long as it has the same format (ECB):
.. code-block:: python
from currency_converter import ECB_URL, SINGLE_DAY_ECB_URL
# Load the packaged data (might not be up to date)
c = CurrencyConverter()
# Download the full history, this will be up to date. Current value is:
# https://www.ecb.europa.eu/stats/eurofxref/eurofxref-hist.zip
c = CurrencyConverter(ECB_URL)
# Dowload only the latest available day. Current value is:
# https://www.ecb.europa.eu/stats/eurofxref/eurofxref.zip
c = CurrencyConverter(SINGLE_DAY_ECB_URL)
# Load your custom file
c = CurrencyConverter('./path/to/currency/file.csv')
Since the raw data is updated only once a day, it might be better to only download it once a day:
.. code-block:: python
import os.path as op
import urllib.request
from datetime import date
from currency_converter import ECB_URL, CurrencyConverter
filename = f"ecb_{date.today():%Y%m%d}.zip"
if not op.isfile(filename):
urllib.request.urlretrieve(ECB_URL, filename)
c = CurrencyConverter(filename)
Fallbacks
~~~~~~~~~
Some rates are missing:
.. code-block:: python
>>> c.convert(100, 'BGN', date=date(2010, 11, 21))
Traceback (most recent call last):
RateNotFoundError: BGN has no rate for 2010-11-21
But we have a fallback mode for those, using a linear interpolation of the
closest known rates, as long as you ask for a date within the currency date bounds:
.. code-block:: python
>>> c = CurrencyConverter(fallback_on_missing_rate=True)
>>> c.convert(100, 'BGN', date=date(2010, 11, 21))
51.12...
The fallback method can be configured with the ``fallback_on_missing_rate_method`` parameter, which currently supports ``"linear_interpolation"`` and ``"last_known"`` values.
We also have a fallback mode for dates outside the currency bounds:
.. code-block:: python
>>> c = CurrencyConverter()
>>> c.convert(100, 'EUR', 'USD', date=date(1986, 2, 2))
Traceback (most recent call last):
RateNotFoundError: 1986-02-02 not in USD bounds 1999-01-04/2016-04-29
>>>
>>> c = CurrencyConverter(fallback_on_wrong_date=True)
>>> c.convert(100, 'EUR', 'USD', date=date(1986, 2, 2)) # fallback to 1999-01-04
117.89...
Decimal
~~~~~~~
If you need exact conversions, you can use the ``decimal`` option to use ``decimal.Decimal`` internally when parsing rates.
This will slow down the load time by a factor 10 though.
.. code-block:: python
>>> c = CurrencyConverter(decimal=True)
>>> c.convert(100, 'EUR', 'USD', date=date(2013, 3, 21))
Decimal('129.100')
Other attributes
~~~~~~~~~~~~~~~~
+ ``bounds`` lets you know the first and last available date for each currency
.. code-block:: python
>>> first_date, last_date = c.bounds['USD']
>>> first_date
datetime.date(1999, 1, 4)
>>> last_date # doctest: +SKIP
datetime.date(2016, 11, 14)
+ ``currencies`` is a set containing all available currencies
.. code-block:: python
>>> c.currencies # doctest: +SKIP
set(['SGD', 'CAD', 'SEK', 'GBP', ...
>>> 'AAA' in c.currencies
False
>>> c.convert(100, 'AAA')
Traceback (most recent call last):
ValueError: AAA is not a supported currency
Raw data
{
"_id": null,
"home_page": "https://github.com/alexprengere/currencyconverter",
"name": "CurrencyConverter",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": null,
"author": "Alex Preng\u00e8re",
"author_email": "alex.prengere@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/06/10/f065abc077e7216abaeae0d10c3904c8d967dd932ee7b2a1c68fdbb4540d/currencyconverter-0.18.2.tar.gz",
"platform": null,
"description": ".. image:: https://raw.githubusercontent.com/alexprengere/currencyconverter/master/logo/cc3.png\n\n|actions|_ |cratev|_ |crated|_\n\n.. _actions : https://github.com/alexprengere/currencyconverter/actions/workflows/python-package.yml\n.. |actions| image:: https://github.com/alexprengere/currencyconverter/actions/workflows/python-package.yml/badge.svg\n\n.. _cratev : https://pypi.org/project/CurrencyConverter/\n.. |cratev| image:: https://img.shields.io/pypi/v/currencyconverter.svg\n\n.. _crated : https://pypi.org/project/CurrencyConverter/\n.. |crated| image:: https://static.pepy.tech/badge/currencyconverter\n\nThis is a currency converter that uses historical rates against a reference currency (Euro). It is compatible with Python3.9+.\n\nCurrency data sources\n---------------------\n\nThe default source is the `European Central Bank <https://www.ecb.europa.eu>`_. This is the ECB historical rates for 42 currencies against the Euro since 1999.\nIt can be downloaded here: `eurofxref-hist.zip <https://www.ecb.europa.eu/stats/eurofxref/eurofxref-hist.zip>`_.\nThe converter can use different sources as long as the format is the same.\n\nNote that the currency converter does not query the API in real time, to avoid the overhead of the HTTP request. It uses embedded data in the library, which might not be up to date.\nIf you need the latest data, please refer to the *data* section.\n\nInstallation\n------------\n\nYou can install directly after cloning:\n\n.. code-block:: bash\n\n $ python setup.py install --user\n\nOr use the Python package:\n\n.. code-block:: bash\n\n $ pip install --user currencyconverter\n\nCommand line tool\n-----------------\n\nAfter installation, you should have ``currency_converter`` in your ``$PATH``:\n\n.. code-block:: bash\n\n $ currency_converter 100 USD --to EUR\n 100.000 USD = 87.512 EUR on 2016-05-06\n \nPython API\n----------\n\nCreate once the currency converter object:\n\n.. code-block:: python\n\n >>> from currency_converter import CurrencyConverter\n >>> c = CurrencyConverter()\n\nConvert from ``EUR`` to ``USD`` using the last available rate:\n\n.. code-block:: python\n\n >>> c.convert(100, 'EUR', 'USD') # doctest: +SKIP\n 137.5...\n\nDefault target currency is ``EUR``:\n\n.. code-block:: python\n\n >>> c.convert(100, 'EUR')\n 100.0\n >>> c.convert(100, 'USD') # doctest: +SKIP\n 72.67...\n\nYou can change the date of the rate:\n\n.. code-block:: python\n\n >>> from datetime import date # datetime works too\n >>> c.convert(100, 'EUR', 'USD', date=date(2013, 3, 21))\n 129...\n\nData\n~~~~\n\nYou can use your own currency file, as long as it has the same format (ECB):\n\n.. code-block:: python\n\n from currency_converter import ECB_URL, SINGLE_DAY_ECB_URL\n\n # Load the packaged data (might not be up to date)\n c = CurrencyConverter()\n\n # Download the full history, this will be up to date. Current value is:\n # https://www.ecb.europa.eu/stats/eurofxref/eurofxref-hist.zip\n c = CurrencyConverter(ECB_URL)\n\n # Dowload only the latest available day. Current value is:\n # https://www.ecb.europa.eu/stats/eurofxref/eurofxref.zip\n c = CurrencyConverter(SINGLE_DAY_ECB_URL)\n\n # Load your custom file\n c = CurrencyConverter('./path/to/currency/file.csv')\n\nSince the raw data is updated only once a day, it might be better to only download it once a day:\n\n.. code-block:: python\n\n import os.path as op\n import urllib.request\n from datetime import date\n\n from currency_converter import ECB_URL, CurrencyConverter\n\n filename = f\"ecb_{date.today():%Y%m%d}.zip\"\n if not op.isfile(filename):\n urllib.request.urlretrieve(ECB_URL, filename)\n c = CurrencyConverter(filename)\n\nFallbacks\n~~~~~~~~~\n\nSome rates are missing:\n\n.. code-block:: python\n\n >>> c.convert(100, 'BGN', date=date(2010, 11, 21))\n Traceback (most recent call last):\n RateNotFoundError: BGN has no rate for 2010-11-21\n\nBut we have a fallback mode for those, using a linear interpolation of the\nclosest known rates, as long as you ask for a date within the currency date bounds:\n\n.. code-block:: python\n\n >>> c = CurrencyConverter(fallback_on_missing_rate=True)\n >>> c.convert(100, 'BGN', date=date(2010, 11, 21))\n 51.12...\n\nThe fallback method can be configured with the ``fallback_on_missing_rate_method`` parameter, which currently supports ``\"linear_interpolation\"`` and ``\"last_known\"`` values.\n\nWe also have a fallback mode for dates outside the currency bounds:\n\n.. code-block:: python\n\n >>> c = CurrencyConverter()\n >>> c.convert(100, 'EUR', 'USD', date=date(1986, 2, 2))\n Traceback (most recent call last):\n RateNotFoundError: 1986-02-02 not in USD bounds 1999-01-04/2016-04-29\n >>> \n >>> c = CurrencyConverter(fallback_on_wrong_date=True)\n >>> c.convert(100, 'EUR', 'USD', date=date(1986, 2, 2)) # fallback to 1999-01-04\n 117.89...\n\nDecimal\n~~~~~~~\n\nIf you need exact conversions, you can use the ``decimal`` option to use ``decimal.Decimal`` internally when parsing rates.\nThis will slow down the load time by a factor 10 though.\n\n.. code-block:: python\n\n >>> c = CurrencyConverter(decimal=True)\n >>> c.convert(100, 'EUR', 'USD', date=date(2013, 3, 21))\n Decimal('129.100')\n\nOther attributes\n~~~~~~~~~~~~~~~~\n\n+ ``bounds`` lets you know the first and last available date for each currency\n\n.. code-block:: python\n\n >>> first_date, last_date = c.bounds['USD']\n >>> first_date\n datetime.date(1999, 1, 4)\n >>> last_date # doctest: +SKIP\n datetime.date(2016, 11, 14)\n\n+ ``currencies`` is a set containing all available currencies\n\n.. code-block:: python\n\n >>> c.currencies # doctest: +SKIP\n set(['SGD', 'CAD', 'SEK', 'GBP', ...\n >>> 'AAA' in c.currencies\n False\n >>> c.convert(100, 'AAA')\n Traceback (most recent call last):\n ValueError: AAA is not a supported currency\n",
"bugtrack_url": null,
"license": null,
"summary": "A currency converter using the European Central Bank data.",
"version": "0.18.2",
"project_urls": {
"Homepage": "https://github.com/alexprengere/currencyconverter"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e074f633d582f8684db8696c5a3ea08e25c5fffd8de0e3272000347f0bebba7a",
"md5": "a48d77027216d3935e6fc29651859509",
"sha256": "0a417d6ca3ffde2c562c288ac1bbf052b3a862c7c856b7be31615057dd3b4684"
},
"downloads": -1,
"filename": "CurrencyConverter-0.18.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "a48d77027216d3935e6fc29651859509",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 615090,
"upload_time": "2025-01-06T09:18:09",
"upload_time_iso_8601": "2025-01-06T09:18:09.451479Z",
"url": "https://files.pythonhosted.org/packages/e0/74/f633d582f8684db8696c5a3ea08e25c5fffd8de0e3272000347f0bebba7a/CurrencyConverter-0.18.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "0610f065abc077e7216abaeae0d10c3904c8d967dd932ee7b2a1c68fdbb4540d",
"md5": "f61c71fd7ec229454f53f09571b49d2b",
"sha256": "8cbe2e152174911a3a23777098a94249e79e543daf08a467e788a0184fba4d34"
},
"downloads": -1,
"filename": "currencyconverter-0.18.2.tar.gz",
"has_sig": false,
"md5_digest": "f61c71fd7ec229454f53f09571b49d2b",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 3808706,
"upload_time": "2025-01-06T09:18:11",
"upload_time_iso_8601": "2025-01-06T09:18:11.600469Z",
"url": "https://files.pythonhosted.org/packages/06/10/f065abc077e7216abaeae0d10c3904c8d967dd932ee7b2a1c68fdbb4540d/currencyconverter-0.18.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-06 09:18:11",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "alexprengere",
"github_project": "currencyconverter",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"tox": true,
"lcname": "currencyconverter"
}