Skip to main content

XNum: Universal Numeral System Converter

Project description

XNum Logo

XNum: Universal Numeral System Converter


PyPI version built with Python3 GitHub repo size Discord Channel

Overview

XNum is a simple and lightweight Python library that helps you convert digits between different numeral systems — like English, Persian, Hindi, Arabic-Indic, Bengali, and more. It can automatically detect mixed numeral formats in a piece of text and convert only the numbers, leaving the rest untouched. Whether you're building multilingual apps or processing localized data, XNum makes it easy to handle numbers across different languages with a clean and easy-to-use API.

PyPI Counter
Github Stars
Branch main dev
CI
Code Quality CodeFactor

Installation

PyPI

Source code

Usage

>>> from xnum import convert, NumeralSystem
>>> print(convert("۱۲۳ apples & ꘤꘥꘦ cars", target=NumeralSystem.ENGLISH))
123 apples & 456 cars
>>> print(convert("۱۲۳ and 456", source=NumeralSystem.PERSIAN, target=NumeralSystem.HINDI))
१२३ and 456

ℹ️ By default, the source parameter is set to NumeralSystem.AUTO, which automatically detects the numeral system

Supported numeral systems

  • English
    • Standard
    • Fullwidth
    • Subscript
    • Superscript
    • Double-Struck
    • Bold
    • Monospace
    • Sans-Serif
    • Sans-Serif Bold
    • Circled
    • Dingbat Circled Sans-Serif
    • Dingbat Negative Circled Sans-Serif
    • Keycap
    • Emoji
    • Full Stop
    • Comma
    • Segmented
  • Persian
  • Hindi
  • Arabic-Indic
  • Bengali
  • Thai
  • Khmer
  • Myanmar
  • Tibetan
  • Gujarati
  • Odia
  • Telugu
  • Kannada
  • Gurmukhi
  • Lao
  • Nko
  • Mongolian
  • Sinhala Lith
  • Myanmar Shan
  • Limbu
  • Vai
  • Ol Chiki
  • Balinese
  • New Tai Lue
  • Saurashtra
  • Javanese
  • Cham
  • Lepcha
  • Sundanese
  • Dives Akuru
  • Modi
  • Takri
  • Newa
  • Tirhuta
  • Sharada
  • Khudawadi
  • Chakma
  • Sora Sompeng
  • Hanifi Rohingya
  • Osmanya
  • Meetei Mayek
  • Kayah Li
  • Gunjala Gondi
  • Masaram Gondi
  • Mro
  • Wancho
  • Adlam
  • Tai Tham Hora
  • Tai Tham Tham
  • Nyiakeng Puachue Hmong
  • Malayalam
  • Brahmi
  • Myanmar Tai Laing

Issues & bug reports

Just fill an issue and describe it. We'll check it ASAP! or send an email to xnum@openscilab.com.

  • Please complete the issue template

You can also join our discord server

Discord Channel

References

1- Unicode - Compart
2- SYMBL (◕‿◕) Symbols, Emojis, Characters, Scripts, Alphabets, Hieroglyphs and the entire Unicode
3- 📙 Emojipedia — 😃 Home of Emoji Meanings 💁👌🎍😍

Show your support

Star this repo

Give a ⭐️ if this project helped you!

Donate to our project

If you do like our project and we hope that you do, can you please support us? Our project is not and is never going to be working for profit. We need the money just so we can continue doing what we do ;-) .

XNum Donation

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

Unreleased

1.3 - 2026-01-28

Added

  • English full stop mode
  • English comma mode
  • English segmented mode
  • Malayalam numeral system
  • Brahmi numeral system
  • Myanmar Tai Laing numeral system

Changed

  • Burmese numeral system renamed to Myanmar

1.2 - 2025-12-11

Added

  • English keycap mode
  • English emoji mode

Changed

  • convert function modified
  • Test system modified
  • README.md updated
  • Digits type changed to list

1.1 - 2025-11-10

Added

  • English circled mode
  • English dingbat circled sans-serif mode
  • English dingbat negative circled sans-serif mode
  • Tai Tham Hora numeral system
  • Tai Tham Tham numeral system
  • Nyiakeng Puachue Hmong numeral system

Changed

  • Test system modified

1.0 - 2025-10-20

Added

  • Sora Sompeng numeral system
  • Hanifi Rohingya numeral system
  • Osmanya numeral system
  • Meetei Mayek numeral system
  • Kayah Li numeral system
  • Gunjala Gondi numeral system
  • Masaram Gondi numeral system
  • Mro numeral system
  • Wancho numeral system
  • Adlam numeral system

Changed

  • README.md updated
  • Python 3.14 added to test.yml

0.9 - 2025-10-10

Added

  • Dives Akuru numeral system
  • Modi numeral system
  • Takri numeral system
  • Newa numeral system
  • Tirhuta numeral system
  • Sharada numeral system
  • Khudawadi numeral system
  • Chakma numeral system

0.8 - 2025-09-28

Added

  • Vai numeral system
  • Ol Chiki numeral system
  • Balinese numeral system
  • New Tai Lue numeral system
  • Saurashtra numeral system
  • Javanese numeral system
  • Cham numeral system
  • Lepcha numeral system
  • Sundanese numeral system

Changed

  • Test system modified

0.7 - 2025-09-17

Added

  • Nko numeral system
  • Mongolian numeral system
  • Sinhala lith numeral system
  • Myanmar shan numeral system
  • Limbu numeral system

Changed

  • Test system modified

0.6 - 2025-09-05

Added

  • English double-struck mode
  • English bold mode
  • English monospace mode
  • English sans-serif mode
  • English sans-serif bold mode

Changed

  • README.md updated
  • Test system modified

0.5 - 2025-09-01

Added

  • Lao numeral system
  • English fullwidth mode
  • English subscript mode
  • English superscript mode

Changed

  • Test system modified
  • README.md updated

0.4 - 2025-08-18

Added

  • Gurmukhi numeral system
  • Kannada numeral system
  • Telugu numeral system

Changed

  • Test system modified
  • README.md updated

0.3 - 2025-08-05

Added

  • Tibetan numeral system
  • Gujarati numeral system
  • Odia numeral system

Changed

  • README.md updated

0.2 - 2025-07-28

Added

  • Thai numeral system
  • Khmer numeral system
  • Burmese numeral system
  • Logo

Changed

  • Test system modified
  • target parameter bug fixed
  • README.md updated

0.1 - 2025-07-20

Added

  • English numeral system
  • Persian numeral system
  • Hindi numeral system
  • Arabic-Indic numeral system
  • Bengali numeral system

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

xnum-1.3.tar.gz (18.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xnum-1.3-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file xnum-1.3.tar.gz.

File metadata

  • Download URL: xnum-1.3.tar.gz
  • Upload date:
  • Size: 18.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for xnum-1.3.tar.gz
Algorithm Hash digest
SHA256 ad1aba4d3429b3606eda780d7c2584167965cfc4d559eab8425118366b3ca23f
MD5 b79f69aa0b95f6750c6ec4031c91be16
BLAKE2b-256 2bd1a1cd5f19c4132537df6f8511321d5910e0764b3e5b544847b5a385a01666

See more details on using hashes here.

File details

Details for the file xnum-1.3-py3-none-any.whl.

File metadata

  • Download URL: xnum-1.3-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for xnum-1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 17fa015ef4f23ecddaf0533273ef6d1a6f48957342b39c7d578cfd9441ca2807
MD5 6432502ad51fa5fc6982aa1a8cb0af79
BLAKE2b-256 c1b75a3dbc688482490a1155aff3267da1e92d4e29523e9507cb36699957bd45

See more details on using hashes here.

Supported by

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