Skip to main content

Modules to convert numbers to words. Easily extensible.

Project description

num2words - Convert numbers to words in multiple languages

https://travis-ci.org/savoirfairelinux/num2words.svg?branch=master https://coveralls.io/repos/github/savoirfairelinux/num2words/badge.svg?branch=master

num2words is a library that converts numbers like 42 to words like forty-two. It supports multiple languages (see the list below for full list 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).

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

The test suite in this library new, so it’s rather thin, but it can be ran with:

python setup.py test

Usage

There’s only one function to use:

>>> from num2words import num2words
>>> num2words(42)
forty-two
>>> num2words(42, to='cardinal')
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

  • ordinal_num

  • year

  • currency

lang: The language in which to convert the number. Supported values are:

  • en (English, default)

  • ar (Arabic)

  • de (German)

  • dk (Danish)

  • en_GB (English - Great Britain)

  • en_IN (English - India)

  • es (Spanish)

  • es_CO (Spanish - Colombia)

  • es_VE (Spanish - Venezuela)

  • eu (EURO)

  • fr (French)

  • fr_CH (French - Switzerland)

  • fr_DZ (French - Algeria)

  • he (Hebrew)

  • id (Indonesian)

  • it (Italian)

  • lt (Lithuanian)

  • lv (Latvian)

  • no (Norwegian)

  • pl (Polish)

  • pt_BR (Brazilian Portuguese)

  • sl (Slovene)

  • ru (Russian)

  • tr (Turkish)

  • vn (Vietnamese)

  • nl (Dutch)

  • uk (Ukrainian)

You can supply values like fr_FR, the code will be correctly interpreted. If you supply an unsupported language, NotImplementedError is raised. 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.

I am thus basing myself on Marius Grigaitis’ improvements and re-publishing pynum2word as num2words.

Virgil Dupras, Savoir-faire Linux

Changelog

Version 0.5.6 – 2017/11/22

  • Refactor to_currency (#135)

  • Allow the use of other convertes to_currency, to_year (#95)

  • Fix code to respect PEP8 (#98, #105)

  • Add Slovene localization (#97)

  • Add Ukrainian localization (#93)

  • Add Dutch localization (#91)

  • Add Algeria-French localization (#86)

  • Add Turkish localization (#85)

Version 0.5.5 – 2017/07/02

  • Add Arabic localization (#72)

  • Add Spanish-Colombian and Spanish-Venezuelan localization (#67)

  • Add VietNam localization (#61)

  • Add Italian localization (#56, #59)

  • Improve Russian localization (#62)

  • Improve Polish localization (#58)

Version 0.5.4 – 2016/10/18

  • Tons of new languages!

  • Add Polish localization. (#23)

  • Add Swiss-French localization. (#38)

  • Add Russian localization. (#28, #46, #48)

  • Add Indonesian localization. (#29)

  • Add Norwegian localization. (#33)

  • Add Danish localization. (#40)

  • Add Brazilian localization. (#37, #47)

  • Improve German localization. (#25, #27, #49)

  • Improve Lithuanian localization. (#52)

  • Improve floating point spelling. (#24)

Version 0.5.3 – 2015/06/09

  • Fix packaging issues. (#21, #22)

Version 0.5.2 – 2015/01/23

  • Added Latvian localization. (#9)

  • Improved Spanish localization. (#10, #13, #14)

  • Improved Lithuanian localization. (#12)

Version 0.5.1 – 2014/03/14

  • Added Python 3 support with 2to3. (#3)

  • Fixed big numbers in spanish. (#2)

  • Fixed bugs in tanslation from 30 to 40 in spanish. (#4)

  • Fixed word joining in english. (#8)

Version 0.5.0 – 2013/05/28

  • Created num2words based on the old pynum2word project.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

num2words-0.5.6.tar.gz (76.4 kB view details)

Uploaded Source

Built Distribution

num2words-0.5.6-py2.py3-none-any.whl (64.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file num2words-0.5.6.tar.gz.

File metadata

  • Download URL: num2words-0.5.6.tar.gz
  • Upload date:
  • Size: 76.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for num2words-0.5.6.tar.gz
Algorithm Hash digest
SHA256 aea26c2d11d636f0e9da094f2bf55ac94cb1c380ff1f86e8db22c210e5a6a05f
MD5 e7a26f40e7340a5fc35ec23213cfde06
BLAKE2b-256 11e04ce77d66ed529a8aa8ea780a43520028f9676064e0efb4e33aa43a0a12b3

See more details on using hashes here.

File details

Details for the file num2words-0.5.6-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for num2words-0.5.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 529017394eef84daf63bb57e837fe2fb81363d1b06f6114e86608dae7ceb11ee
MD5 08a8f08e58d3aeda1f83fd11a97252c0
BLAKE2b-256 aa6e6d026d15d1b0fd37a9dd42ecf559f36871cee67158aff5ba652d3130e8b9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page