Skip to main content

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

  1. Configuring environment variables:

    • Windows:

      • Set the ICU_ROOT environment variable to the root of the ICU installation (default is C:\icu). For example, if the ICU is located in C:\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 and LD_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
        
  2. 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., kDateOffsetDATE_OFFSET)

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


Download files

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

Source Distribution

icupy-0.11.0.tar.gz (497.1 kB view details)

Uploaded Source

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

Hashes for icupy-0.11.0.tar.gz
Algorithm Hash digest
SHA256 ab39de2ccbe3cca031c375d7e3ee3fc726f86a923719b742d1953e5a927c42b3
MD5 38207ed7a7de8b879a6e59c8078874c6
BLAKE2b-256 4ce2e1ede3aedc3c86941a36192e9b764e6d300ab530ad040afbfd3a315b0aae

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