Files
num2words/README.rst

105 lines
3.0 KiB
ReStructuredText
Raw Normal View History

2013-05-28 11:34:53 -04:00
num2words - Convert numbers to words in multiple languages
==========================================================
.. image:: https://travis-ci.org/savoirfairelinux/num2words.svg?branch=master
:target: https://travis-ci.org/savoirfairelinux/num2words
.. image:: https://coveralls.io/repos/github/savoirfairelinux/num2words/badge.svg?branch=master
:target: https://coveralls.io/github/savoirfairelinux/num2words?branch=master
2017-10-22 18:06:49 +02:00
``num2words`` is a library that converts numbers like ``42`` to words like ``forty-two``.
2017-09-12 00:57:01 +02:00
It supports multiple languages (see the list below for full list
2017-09-07 09:39:20 +03:00
of languages) and can even generate ordinal numbers like ``forty-second``
(although this last feature is a bit buggy for some languages at the moment).
2013-05-28 11:34:53 -04:00
The project is hosted on https://github.com/savoirfairelinux/num2words
Installation
------------
The easiest way to install ``num2words`` is to use pip::
pip install num2words
Otherwise, you can download the source package and then execute::
python setup.py install
2015-04-06 15:11:59 -04:00
The test suite in this library new, so it's rather thin, but it can be ran with::
python setup.py test
2013-05-28 11:34:53 -04:00
Usage
-----
There's only one function to use::
>>> from num2words import num2words
>>> num2words(42)
forty-two
>>> num2words(42, to='cardinal')
2013-05-28 11:34:53 -04:00
forty-second
>>> num2words(42, lang='fr')
quarante-deux
Besides the numerical argument, there's two optional arguments.
**to:** The converter to use. Supperted values are
* ``cardinal`` (default)
* ``ordinal``
* ``year``
* ``currency``
2013-05-28 11:34:53 -04:00
**lang:** The language in which to convert the number. Supported values are:
2017-09-07 09:39:20 +03:00
* ``en`` (English, default)
2017-06-21 22:22:27 +03:00
* ``ar`` (Arabic)
* ``de`` (German)
* ``dk`` (Danish)
2017-09-07 09:39:20 +03:00
* ``en_GB`` (English - Great Britain)
* ``en_IN`` (English - India)
* ``es`` (Spanish)
2017-09-07 09:39:20 +03:00
* ``es_CO`` (Spanish - Colombia)
* ``es_VE`` (Spanish - Venezuela)
* ``eu`` (EURO)
* ``fr`` (French)
2017-09-07 09:39:20 +03:00
* ``fr_CH`` (French - Switzerland)
* ``fr_DZ`` (French - Algeria)
* ``he`` (Hebrew)
2017-09-07 09:39:20 +03:00
* ``id`` (Indonesian)
* ``it`` (Italian)
* ``lt`` (Lithuanian)
* ``lv`` (Latvian)
2016-01-11 19:35:11 +01:00
* ``no`` (Norwegian)
* ``pl`` (Polish)
2016-02-27 12:36:33 -03:00
* ``pt_BR`` (Brazilian Portuguese)
2017-10-22 18:06:49 +02:00
* ``sl`` (Slovene)
* ``ru`` (Russian)
2017-09-07 09:39:20 +03:00
* ``tr`` (Turkish)
* ``vn`` (Vietnamese)
2017-09-08 19:29:37 +02:00
* ``nl`` (Dutch)
2017-09-08 17:47:42 +03:00
* ``uk`` (Ukrainian)
2017-09-08 19:29:37 +02:00
You can supply values like ``fr_FR``, the code will be correctly interpreted. If
you supply an unsupported language, ``NotImplementedError`` is raised.
2013-05-28 11:34:53 -04:00
Therefore, if you want to call ``num2words`` with a fallback, you can do::
try:
return num2words(42, lang=mylang)
except NotImplementedError:
return num2words(42, lang='en')
History
-------
``num2words`` is based on an old library, ``pynum2word`` created by Taro Ogawa
in 2003. Unfortunately, the library stopped being maintained and the author
can't be reached. There was another developer, Marius Grigaitis, who in 2011
added Lithuanian support, but didn't take over maintenance of the project.
2013-05-28 11:34:53 -04:00
I am thus basing myself on Marius Grigaitis' improvements and re-publishing
``pynum2word`` as ``num2words``.
2013-05-28 11:34:53 -04:00
Virgil Dupras, Savoir-faire Linux