Python bindings for ICU4C
Project description
icupy
Python bindings for ICU4C using pybind11.
Installation
Prerequisites
- Python >=3.7
- ICU4C (>=64 recommended)
- C++17 compatible compiler (See supported compilers)
- Windows: Visual Studio 2015 Update 3 or newer. Visual Studio 2019 recommended.
- CMake >=3.7
Installing prerequisites
To install dependencies, run the following command:
-
Ubuntu/Debian:
sudo apt install g++ cmake libicu-dev python3-dev python3-pip
-
Fedora:
sudo dnf install gcc-c++ cmake icu libicu-devel python3-devel
-
openSUSE:
If default Python version is 3.8:
sudo zypper install gcc-c++ cmake icu libicu-devel python38-devel python38-pip
Building from source
-
Configuring environment variables:
-
Windows:
-
Set the
ICU_ROOT
environment variable to the root of the ICU installation (default isC:\icu
). For example, if the ICU is located inC:\icu4c
:set ICU_ROOT=C:\icu4c
or in PowerShell:
$env:ICU_ROOT = "C:\icu4c"
-
-
Linux/POSIX:
-
If the ICU is located in a non-regular place, set the
PKG_CONFIG_PATH
andLD_LIBRARY_PATH
environment variables. For example, if the ICU is located in/usr/local
:export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
-
-
-
Installing from PyPI:
pip install icupy
Alternatively, installing development version from the git repository:
pip install git+https://github.com/miute/icupy.git@develop
Optionally, CMake environment variables are available. For example, using the Ninja build system and Clang:
CMAKE_GENERATOR=Ninja CXX=clang pip install icupy
Changes from ICU4C
- Naming Rules
- Renamed C functions and C++ class methods from mixed case to snake case. (e.g.,
findAndReplace()
→find_and_replace()
) - Renamed C++ enumerators to upper snake case without "k" prefix. (e.g.,
kDateOffset
→DATE_OFFSET
)
- Renamed C functions and C++ class methods from mixed case to snake case. (e.g.,
Examples
-
icu::UnicodeString with error callback
>>> import icupy.icu as icu >>> cnv = icu.ucnv_open("utf-8") >>> action = icu.UCNV_TO_U_CALLBACK_ESCAPE >>> context = icu.ConstVoidPtr(icu.UCNV_ESCAPE_C) >>> icu.ucnv_set_to_ucall_back(cnv, action, context) >>> utf8 = b"\x61\xfe\x62" # Impossible bytes >>> s = icu.UnicodeString(utf8, -1, cnv) >>> str(s) 'a\\xFEb'
-
icu::IDNA (UTS #46)
>>> import icupy.icu as icu >>> uts46 = icu.IDNA.create_uts46_instance(icu.UIDNA_NONTRANSITIONAL_TO_ASCII) >>> dest = icu.UnicodeString() >>> info = icu.IDNAInfo() >>> uts46.name_to_ascii(icu.UnicodeString("faß.ExAmPlE"), dest, info) UnicodeString('xn--fa-hia.example') >>> str(dest) 'xn--fa-hia.example'
-
See also tests directory.
License
This project is licensed under the MIT License.
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
File details
Details for the file icupy-0.11.0.tar.gz
.
File metadata
- Download URL: icupy-0.11.0.tar.gz
- Upload date:
- Size: 497.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ab39de2ccbe3cca031c375d7e3ee3fc726f86a923719b742d1953e5a927c42b3 |
|
MD5 | 38207ed7a7de8b879a6e59c8078874c6 |
|
BLAKE2b-256 | 4ce2e1ede3aedc3c86941a36192e9b764e6d300ab530ad040afbfd3a315b0aae |