Charamel
π Truly Universal Encoding Detection in Python π
Install / Use
/learn @chomechome/CharamelREADME
<img alt="Package version" src="https://img.shields.io/pypi/v/charamel.svg"/> <img alt="Package license" src="https://img.shields.io/pypi/l/charamel.svg"/> <img alt="Python versions" src="https://img.shields.io/pypi/pyversions/charamel.svg"/> <img alt="TravisCI status" src="https://travis-ci.org/chomechome/charamel.svg?branch=master"/> <img alt="Code coverage" src="https://codecov.io/github/chomechome/charamel/coverage.svg?branch=master"/> <img alt="Code quality" src="https://codeclimate.com/github/chomechome/charamel/badges/gpa.svg?branch=master"/>
Truly Universal Encoding Detection in Python
Charamel is a pure Python universal character encoding library that supports all of Python character encodings. The library is based on machine learning and trained to handle more than 60 languages. All that with no external dependencies. Ain't it sweet? π
Installation
$ pip install charamel
Features
- π Powered by machine learning
- π¦ No dependencies
- β‘ Faster than other pure Python libraries
- π Supports all 98 Python encodings
- π Works on 60+ languages
- π 97% accuracy
Usage
API is centered around Detector class, with detect method being responsible for basic encoding detection:
>>> from charamel import Detector
>>> detector = Detector()
>>> content = b'El espa\xf1ol o castellano del lat\xedn hablado'
>>> detector.detect(content)
<Encoding.ISO_8859_14: 'iso8859_14'>
This returns the most likely encoding that can decode the byte string. Let's try it out:
>>> from charamel import Encoding
>>> content.decode(Encoding.ISO_8859_14)
'El espaΓ±ol o castellano del latΓn hablado'
To get multiple likely encodings along with confidences in range [0, 1], use probe method:
>>> detector.probe(content, top=3)
[(<Encoding.ISO_8859_14: 'iso8859_14'>, 0.9964286725192874),
(<Encoding.CP_1258: 'cp1258'>, 0.9919203166700203),
(<Encoding.ISO_8859_3: 'iso8859_3'>, 0.9915028923264849)]
Detector can be configured to use a subset of encodings. Less possible encodings lead to faster detection:
>>> detector = Detector(encodings=[Encoding.UTF_8, Encoding.BIG_5])
Another useful Detector parameter is min_confidence. Basically, this parameter regulates how conservative the Detector will be.
Confidence for encodings that are returned by detect and probe methods must be greater that min_confidence:
>>> detector = Detector(min_confidence=0.5)
If no encoding confidences exceed min_confidence, detect will return None and probe will return an empty list.
Benchmark
Below is the comparison between Charamel and other available Python encoding detection libraries:
| Detector | Supported Encodings | Sec / File (Mean) | Sec / File (99%) | Sec / File (Max) | KB / Sec | Accuracy | Accuracy on Supported | |---------------------------------------------------------------------------|-----------------------|---------------------|--------------------|--------------------|------------|------------|-------------------------| | Chardet v3.0.4 | 26 | 0.029259 | 0.416156 | 3.115 | 220 | 61% | 97% | | Cchardet v2.1.6 | 40 | 0.000383 | 0.003913 | 0.062855 | 16811 | 67% | 79% | | Charset-Normalizer v1.3.4 | 89 | 0.126674 | 0.502882 | 1.41848 | 51 | 77% | 78% | | Charamel v1.0.0 | 98 | 0.009053 | 0.04277 | 0.120667 | 712 | 97% | 97% |
How to run this benchmark (requires Python 3.6+):
$ git clone git@github.com:chomechome/charamel.git
$ cd charamel
$ pip install poetry>=1.0.5
$ make benchmark
It also produces a detailed breakdown for all represented encodings:
* - not officially support for detector
| Encoding | Total | Chardet v3.0.4 | Cchardet v2.1.6 | Charset-Normalizer v1.3.4 | Charamel v1.0.0 | |-----------------|---------|------------------|-------------------|-----------------------------|-------------------| | ascii | 8 | 7 (88%) | 8 (100%) | 7 (88%) | 8 (100%) | | big5 | 33 | 33 (100%) | 33 (100%) | 32 (97%) | 31 (94%) | | big5hkscs | 9 | 6 (67%) * | 6 (67%) * | 8 (89%) | 9 (100%) | | cp037 | 14 | 0 (0%) * | 0 (0%) * | 12 (86%) | 14 (100%) | | cp1006 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) * | 4 (100%) | | cp1026 | 14 | 0 (0%) * | 0 (0%) * | 10 (71%) | 14 (100%) | | cp1125 | 5 | 4 (80%) * | 4 (80%) * | 5 (100%) | 5 (100%) | | cp1140 | 14 | 0 (0%) * | 0 (0%) * | 12 (86%) | 14 (100%) | | cp1250 | 23 | 7 (30%) * | 22 (96%) | 11 (48%) | 23 (100%) | | cp1251 | 45 | 44 (98%) | 45 (100%) | 45 (100%) | 45 (100%) | | cp1252 | 36 | 36 (100%) | 30 (83%) | 18 (50%) | 36 (100%) | | cp1253 | 6 | 4 (67%) | 6 (100%) | 6 (100%) | 6 (100%) | | cp1254 | 16 | 15 (94%) * | 13 (81%) * | 12 (75%) | 16 (100%) | | cp1255 | 29 | 29 (100%) | 29 (100%) | 29 (100%) | 29 (100%) | | cp1256 | 8 | 6 (75%) * | 7 (88%) | 8 (100%) | 8 (100%) | | cp1257 | 13 | 7 (54%) * | 10 (77%) | 6 (46%) | 13 (100%) | | cp1258 | 15 | 14 (93%) * | 12 (80%) * | 12 (80%) | 15 (100%) | | cp273 | 14 | 0 (0%) * | 0 (0%) * | 7 (50%) | 14 (100%) | | cp424 | 4 | 0 (0%) * | 0 (0%) * | 4 (100%) | 4 (100%) | | cp437 | 11 | 4 (36%) * | 4 (36%) * | 9 (82%) | 11 (100%) | | cp500 | 14 | 0 (0%) * | 0 (0%) * | 7 (50%) | 14 (100%) | | cp720 | 6 | 4 (67%) * | 4 (67%) * | 6 (100%) * | 6 (100%) | | cp737 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) * | 4 (100%) | | cp775 | 11 | 4 (36%) * | 4 (36%) * | 8 (73%) | 11 (100%) | | cp850 | 14 | 4 (29%) * | 4 (29%) * | 11 (79%) | 14 (100%) | | cp852 | 14 | 4 (29%) * | 12 (86%) | 6 (43%) | 14 (100%) | | cp855 | 26 | 26 (100%) | 26 (100%) | 26 (100%) | 26 (100%) | | cp856 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) * | 4 (100%) | | cp857 | 14 | 4 (29%) * | 4 (29%) * | 11 (79%) | 14 (100%) | | cp858 | 14 | 4 (29%) * | 4 (29%) * | 11 (79%) | 14 (100%) | | cp860 | 7 | 4 (57%) * | 4 (57%) * | 6 (86%) | 7 (100%) | | cp861 | 9 | 4 (44%) * | 4 (44%) * | 8 (89%) | 9 (100%) | | cp862 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) | 4 (100%) | | cp863 | 7 | 4 (57%) * | 4 (57%) * | 6 (86%) | 7 (100%) | | cp864 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) | 4 (100%) | | cp865 | 12 | 4 (33%) * | 4 (33%) * | 10 (83%) | 12 (100%) | | cp866 | 23 | 23 (100%) | 23 (100%) | 23 (100%) | 23 (100%) | | cp869 | 4 | 4 (100%) * | 4 (100%) * | 4 (100%) | 4 (100%) | | cp874 | 8 | 6 (75%) * | 7 (88%) * | 8 (100%) * | 8 (100%) | | cp875 | 4 | 0 (0%) * | 0 (0%) * | 3 (75%) * | 4 (100%) | | cp932 | 11 | 11 (100%) | 8 (73%) * | 11 (100%) | 9 (82%) | | cp949 | 6 | 6 (100%) * | 6 (100%) | 6 (100%) | 6 (100%) | | cp950 | 6 | 6 (100%) * | 6 (100%) * | 6 (
Related Skills
node-connect
343.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
claude-opus-4-5-migration
90.0kMigrate prompts and code from Claude Sonnet 4.0, Sonnet 4.5, or Opus 4.1 to Opus 4.5
frontend-design
90.0kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
model-usage
343.1kUse CodexBar CLI local cost usage to summarize per-model usage for Codex or Claude, including the current (most recent) model or a full model breakdown. Trigger when asked for model-level usage/cost data from codexbar, or when you need a scriptable per-model summary from codexbar cost JSON.
