Skip to main content

encode / decode italian fiscal codes - codifica / decodifica del Codice Fiscale italiano.

Project description

python-codicefiscale

python-codicefiscale is a library for encode/decode Italian fiscal code - codifica/decodifica del Codice Fiscale.

Codice Fiscale

Features

  • NEW Auto-updated data (once a week) directly from ANPR data-source.
  • NEW Command Line Interface available.
  • Transliteration for name/surname
  • Multiple birthdate formats (date/string) (you can see all the supported string formats here)
  • Automatic birthplace city/foreign-country code detection from name
  • Omocodia support

Installation

pip install python-codicefiscale

Usage

Python

Import

from codicefiscale import codicefiscale

Encode

codicefiscale.encode(
    lastname="Caccamo",
    firstname="Fabio",
    gender="M",
    birthdate="03/04/1985",
    birthplace="Torino",
)

# "CCCFBA85D03L219P"

Decode

codicefiscale.decode("CCCFBA85D03L219P")

# {
#     "code": "CCCFBA85D03L219P",
#     "gender": "M",
#     "birthdate": datetime.datetime(1985, 4, 3, 0, 0),
#     "birthplace": {
#         "name": "TORINO"
#         "province": "TO",
#         "code": "L219",
#     },
#     "omocodes": [
#         "CCCFBA85D03L219P",
#         "CCCFBA85D03L21VE",
#         "CCCFBA85D03L2MVP",
#         "CCCFBA85D03LNMVE",
#         "CCCFBA85D0PLNMVA",
#         "CCCFBA85DLPLNMVL",
#         "CCCFBA8RDLPLNMVX",
#         "CCCFBAURDLPLNMVU",
#     ],
#     "raw": {
#         "code": "CCCFBA85D03L219P",
#         "lastname": "CCC",
#         "firstname": "FBA",
#         "birthdate": "85D03",
#         "birthdate_year": "85"
#         "birthdate_month": "D",
#         "birthdate_day": "03",
#         "birthplace": "L219",
#         "cin": "P",
#     },
# }

Check

codicefiscale.is_valid("CCCFBA85D03L219P")

# True
codicefiscale.is_omocode("CCCFBA85D03L219P")

# False

Command Line

[!CAUTION] If sensitive data is written to a log entry it could be exposed to an attacker who gains access to the logs.

This library can be used also as a CLI tool, for more info run:

python -m codicefiscale --help

Encode (CLI)

python -m codicefiscale encode --firstname Fabio --lastname Caccamo --gender M --birthdate 03/04/1985 --birthplace Torino

Decode (CLI)

python -m codicefiscale decode CCCFBA85D03L219P

Testing

# clone repository
git clone https://github.com/fabiocaccamo/python-codicefiscale.git && cd python-codicefiscale

# create virtualenv and activate it
python -m venv venv && . venv/bin/activate

# upgrade pip
python -m pip install --upgrade pip

# install requirements
pip install -r requirements.txt -r requirements-test.txt

# install pre-commit to run formatters and linters
pre-commit install --install-hooks

# run tests using tox
tox

# or run tests using pytest
pytest

License

Released under MIT License.


Supporting

  • :star: Star this project on GitHub
  • :octocat: Follow me on GitHub
  • :blue_heart: Follow me on Bluesky
  • :moneybag: Sponsor me on Github

See also

  • python-benedict - dict subclass with keylist/keypath support, I/O shortcuts (base64, csv, json, pickle, plist, query-string, toml, xml, yaml) and many utilities. 📘

  • python-fontbro - friendly font operations. 🧢

  • python-fsutil - file-system utilities for lazy devs. 🧟‍♂️

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

python_codicefiscale-0.11.4.tar.gz (421.3 kB view details)

Uploaded Source

Built Distribution

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

python_codicefiscale-0.11.4-py3-none-any.whl (432.2 kB view details)

Uploaded Python 3

File details

Details for the file python_codicefiscale-0.11.4.tar.gz.

File metadata

  • Download URL: python_codicefiscale-0.11.4.tar.gz
  • Upload date:
  • Size: 421.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for python_codicefiscale-0.11.4.tar.gz
Algorithm Hash digest
SHA256 2c1e2921e4fb46a5f8ff8f1079f0f7d95df32b63f1e31b27d8d9d92b2552e789
MD5 60bf74ec0d8d0980f43bab2dedf607b0
BLAKE2b-256 14438c59ad3c04335e58562c59bd95a70a1bf234fb2ab036c21849843a7713a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_codicefiscale-0.11.4.tar.gz:

Publisher: create-release.yml on fabiocaccamo/python-codicefiscale

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file python_codicefiscale-0.11.4-py3-none-any.whl.

File metadata

File hashes

Hashes for python_codicefiscale-0.11.4-py3-none-any.whl
Algorithm Hash digest
SHA256 3007644b27db3ee02a3c7d20be96ad2b40a344f26e63ffdb0ef3bbd0cf23a6fb
MD5 c2cc1d55da51d645de23baf6e354a330
BLAKE2b-256 4b01287f68a3a3acd23e80a8e9b6dd0262b408468006477cb6abf07bc62d22ac

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_codicefiscale-0.11.4-py3-none-any.whl:

Publisher: create-release.yml on fabiocaccamo/python-codicefiscale

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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