A library for biredirectional conversion between numeral systems. Supports 46 different systems across all numeral systems available in Unicode. Families include Aramaic, Brahmi, Cuneiform, Egyptian, Ethiopic, Greek, Hebrew, Hindu-Arabic, Kaktovik, Kharosthi, Mayan, Medefaidrin, Nabataean, Pahlavi, Phoenician, Roman, Sino-Tibetan, Siyaq, Sogdian, and South Arabian.
Project description
Swopy
A library for biredirectional conversion between numeral systems. Supports 46 different systems across all numeral systems available in Unicode.
Supported Numeral Systems
- Aramaic:
Hatran, supporting integers between 1 and 999ImperialAramaic, supporting integers between 1 and 99,999Palmyrene, supporting integers between 1 and 99
- Brahmi:
Brahmi, supporting integers between 1 and 9,999
- Brahmi-Dravidian:
Grantha, supporting integers between 0 and infinity (base-7 positional)Saurashtra, supporting integers between 0 and infinityTamil, supporting integers between 1 and 9,999
- Brahmi-Gupta:
Bhaiksuki, supporting integers between 1 and 999SinhalaArchaic, supporting integers between 1 and 9,999
- Brahmi-Tai:
Ahom, supporting integers between 0 and infinity
- Cuneiform:
Cuneiform, supporting integers between 1 and 999
- Egyptian:
Egyptian, supporting integers between 1 and 1,000,000/manyCopticEpact, supporting integers between 1 and 9,999
- Ethiopic:
Ethiopic, supporting integers between 1 and 99,999,999
- Greek:
Aegean, supporting integers between 1 and 99,999Alphabetic, supporting integers between 1 and 9,999Attic, supporting integers and base-4 fractions between 1/4 and 99,999Etruscan, supporting integers between 1 and 399Milesian, supporting integers between 1 and 9,999
- Hebrew:
Hebrew, supporting integers between 1 and 9,999
- Hindu-Arabic:
Arabic, supporting integers, floats and fractions between-math.infandmath.inf. Also available inarabic.ArabicBakhshali, supporting integers between 1 and 9,999
- Kaktovik:
Kaktovik, supporting integers between -infinity and +infinity
- Kharosthi:
Kharosthi, supporting integers between 1 and 9,999
- Mayan:
Mayan, supporting integers between 0 and infinity
- Medefaidrin:
Medefaidrin, supporting integers between 0 and infinity (base-20 positional)
- Nabataean:
Nabataean, supporting integers between 1 and 999
- Numeric Systems:
CountingRod, supporting integers between 1 and 99
- Pahlavi:
InscriptionalParthian, supporting integers between 1 and 9,999InscriptionalPahlavi, supporting integers between 1 and 9,999PsalterPahlavi, supporting integers between 1 and 999
- Phoenician:
Phoenician, supporting integers between 1 and 999
- Roman, in the forms:
Early, supporting integers between 1 and 899Standard, supporting integers and base-12 fractions between 1/12 and 3,999Apostrophus, supporting integers between 1 and 100,000
- Sino-Tibetan:
Chinese, supporting integers between 1 and 99,999,999Khitan, supporting integers between 1 and 99,999,999Suzhou, supporting integers between 0 and infinityTangut, supporting integers between 1 and 99,999,999
- Siyaq:
IndicSiyaq, supporting integers between 1 and 99,999OttomanSiyaq, supporting integers between 1 and 99,999
- Sogdian:
Manichaean, supporting integers between 1 and 999OldSogdian, supporting integers between 1 and 999Sogdian, supporting integers between 1 and 999
- South Arabian:
AncientNorthArabian, supporting integers between 1 and 99AncientSouthArabian, supporting integers between 1 and 99,999
Installation
Install the package:
pip install swopy # or
uv add swopy
Usage
Basic Conversion
import swopy
from swopy import systems
# Convert integer Roman numeral to Egyptian hieroglyphic
swopy.swop('IX', systems.roman.Standard, systems.egyptian.Egyptian)
# '𓏺𓏺𓏺𓏺𓏺𓏺𓏺𓏺𓏺'
# Convert Apostrophus to an Arabic integer
swopy.swop('IↃI', systems.roman.Apostrophus, systems.arabic.Arabic)
# 501
Available Systems
import swopy
import pprint
systems = swopy.get_all_systems()
pprint.pprint(systems)
#{'arabic.Arabic': <class 'swopy.systems.arabic.Arabic'>,
# 'egyptian.Egyptian': <class 'swopy.systems.egyptian.Egyptian'>,
# 'etruscan.Etruscan': <class 'swopy.systems.etruscan.Etruscan'>,
# 'greek.Milesian': <class 'swopy.systems.greek.Milesian'>,
# 'roman.Apostrophus': <class 'swopy.systems.roman.Apostrophus'>,
# 'roman.Early': <class 'swopy.systems.roman.Early'>,
# 'roman.Standard': <class 'swopy.systems.roman.Standard'>
# ...}
swopy.swop(42, systems['arabic.Arabic'], systems['roman.Early'])
# 'XLII'
Error Handling
Swopy will raise a ValueError if there is a number is not representable in a numeral system
import swopy
from swopy import systems
swopy.swop(4000, systems.arabic.Arabic, systems.roman.Standard)
# ValueError: Number must be less than or equal to 3999.
systems.roman.Early.to_numeral(900)
# ValueError: Number must be less than or equal to 899.
or if a numeral is invalid
import swopy
from swopy import systems
swopy.swop('IIIII', systems.egyptian.Egyptian, systems.roman.Early)
# ValueError: Invalid Egyptian hieroglyph: I
systems.roman.Apostrophus.from_numeral('P')
# ValueError: Invalid Apostrophus characters at position 0
and will raise a TypeError if a numeral is not representable in a system.
import swopy
from swopy import systems
swopy.swop(1.2, systems.arabic.Arabic, systems.roman.Early)
# TypeError: 1.2 of type float cannot be represented in Early.
swopy.swop('I', systems.arabic.Arabic, systems.roman.Early)
# TypeError: I of type str cannot be represented in Arabic.
systems.egyptian.Egyptian.to_numeral(10.1)
# TypeError: 10.1 of type float cannot be represented in Egyptian.
Requirements
Swopy only relies on the standard library and needs Python 3.13 or higher. Swopy is currently tested on the latest versions of Windows, MacOS and Ubuntu for Python versions 3.13, 3.14.0, 3.14.3, and 3.15.
Development
Dependencies
Development dependencies are managed through pyproject.toml:
# Install development dependencies
sh scripts/startup.sh
Dev tools include:
- pytest / pytest-cov: Testing framework
- ruff: Fast Python linter and formatter
- pyright: Static type checker
- deptry: Dependency validation
- hypothesis: Property-based testing
- pre-commit: Git hooks framework
- tox, with tox-uv: Test runner
- uv
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swopy-0.1.15.tar.gz.
File metadata
- Download URL: swopy-0.1.15.tar.gz
- Upload date:
- Size: 124.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b7cb35ef95721af13c18677e460a9d4b7fb5490eae0d59bf467655da160a271
|
|
| MD5 |
5d81a4d5994d146e1d699884a264bd0d
|
|
| BLAKE2b-256 |
bf8d8caa93471a171febb0f8f5cfc06940963d1dac9f8f4073f3a62dbbc34d88
|
File details
Details for the file swopy-0.1.15-py3-none-any.whl.
File metadata
- Download URL: swopy-0.1.15-py3-none-any.whl
- Upload date:
- Size: 101.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
734dc51d738d2dcc73cf996e724608a6aafd3a17192661bdea1c095399bf2c32
|
|
| MD5 |
b516793847de124c1abc9d244e333ef1
|
|
| BLAKE2b-256 |
fa9ff651b4a9280660fab972f092b6a4122a543d6979a389e356a18e246816b8
|