Skip to main content

A module to anonymize french text data

Project description

Incognito

Description

Incognito is a Python module for anonymizing French text. It uses Regex and other strategies to mask names and personal information provided by the user.
This module was specifically designed for medical reports, ensuring that disease names remain unaltered.

python


Installation

From pip

pip install incognito-anonymizer

From this repository

  1. Clone the repository:

    git clone https://github.com/Micropot/incognito
    
  2. Install the dependencies (defined in pyproject.toml):

    pip install .
    

Usage

Python API

Example: Providing Personal Information Directly in Code

from . import anonymizer

# Initialize the anonymizer
ano = anonymizer.Anonymizer()

# Define personal information
infos = {
    "first_name": "Bob",
    "last_name": "Jungels",
    "birth_name": "",
    "birthdate": "1992-09-22",
    "ipp": "0987654321",
    "postal_code": "01000",
    "adress": ""
}

# Configure the anonymizer
ano.set_info(infos)
ano.add_analyser('pii')
ano.add_analyser('regex')
ano.add_analyser('lossy') # trigger a warning. See doc string for better understanding
ano.set_mask('placeholder')

# Read and anonymize text
text_to_anonymize = ano.open_text_file("/path/to/file.txt")
anonymized_text = ano.anonymize(text_to_anonymize)

print(anonymized_text)

Example: Using JSON File for Personal Information

from . import anonymizer

# Initialize the anonymizer
ano = anonymizer.Anonymizer()

# Load personal information from JSON
infos_json = ano.open_json_file("/path/to/infofile.json")

# Configure the anonymizer
ano.set_info(infos_json)
ano.add_analyser('pii')
ano.add_analyser('regex')
ano.set_mask('placeholder')

# Read and anonymize text
text_to_anonymize = ano.open_text_file("/path/to/file.txt")
anonymized_text = ano.anonymize(text_to_anonymize)

print(anonymized_text)

Example: Annote a file

from . import anonymizer

# Initialize the anonymizer
ano = anonymizer.Anonymizer()

# Load personal information from JSON
infos_json = ano.open_json_file("/path/to/infofile.json")

# Configure the annotator
ano.set_info(infos_json)
ano.add_analyser('pii')
ano.add_analyser('regex')
ano.set_annotator('placeholder')

# Read and annotate text
text_to_anonymize = ano.open_text_file("/path/to/file.txt")
annotated_text = ano.annotate(text_to_anonymize)

print(annotated_text)

Command-Line Interface (CLI)

Basic Usage

python -m incognito --input myinputfile.txt --output myanonymizedfile.txt --strategies mystrategies --mask mymasks

Find Available Strategies, Masks and Annotator

python -m incognito --help

Anonymization with JSON File

python -m incognito --input myinputfile.txt --output myanonymizedfile.txt --strategies mystrategies --mask mymasks json --json myjsonfile.json

To view helper options for the JSON submodule:

python -m incognito json --help

Anonymization with Personal Information in CLI

python -m incognito --input myinputfile.txt --output myanonymizedfile.txt --strategies mystrategies --mask mymasks infos --first_name Bob --last_name Dylan --birthdate 1800-01-01 --ipp 0987654312 --postal_code 75001

To view helper options for the "infos" submodule:

python -m incognito infos --help

Annotation

python -m incognito --input myinputfile.txt --output annotationfile.ann --strategies mystrategies --annotate myannotator infos --first_name Bob --last_name Dylan --birthdate 1800-01-01 --ipp 0987654312 --postal_code 75001

Unit Tests

Unit tests are included to ensure the module's functionality. You can modify them based on your needs.

To run the tests:

make test

To check code coverage:

make cov

Anonymization Process Details

Regex Strategy

One available anonymization strategy is Regex. It can extract and mask specific information from the input text, such as:

  • Email addresses
  • Phone numbers
  • French NIR (social security number)
  • First and last names (if preceded by titles like "Monsieur", "Madame", "Mr", "Mme", "Docteur", "Professeur", etc.)

For more details, see the RegexStrategy class and the self.title_regex variable.

PII Stategy

This strategy is used to catch the personal informations of the patient.

You can use it in CLI with the infos or in a json fil.

For further example you can see the CLI chapter

Lossy Strategy

Another available anonymization strategy is Lossy. The idea is to mask pattern like DUPONT Marc or Marc DUPONT.

!!!warn

It can produce false positive. Be aware that this strategy can can unexpected matched and  loose informations in your text

For more details, see the LossyStrategy class

Anotation Process Details

Standoff Strategy

You can create an annotation file based on the Standoff format.

This file will be automatically created based on the matched entity.

You can find example in the CLI/API chapters


License

This project is licensed under the terms of the MIT License.


Contributors

  • Maintainer: Micropot
    Feel free to open issues or contribute via pull requests!

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

incognito_anonymizer-1.4.3.tar.gz (122.8 kB view details)

Uploaded Source

Built Distribution

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

incognito_anonymizer-1.4.3-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file incognito_anonymizer-1.4.3.tar.gz.

File metadata

  • Download URL: incognito_anonymizer-1.4.3.tar.gz
  • Upload date:
  • Size: 122.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.0 {"installer":{"name":"uv","version":"0.11.0","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

Hashes for incognito_anonymizer-1.4.3.tar.gz
Algorithm Hash digest
SHA256 8a70f9ebe20acd23457849ebed2f494c0ded6aa0a4ad26bc3db8e071ce50e613
MD5 3767fffa15cf1f88fbb477670bf28513
BLAKE2b-256 9f9784e43f5ff8785f9020763dfbfddf3da32601ad6289b393c01ae8b972ec0e

See more details on using hashes here.

File details

Details for the file incognito_anonymizer-1.4.3-py3-none-any.whl.

File metadata

  • Download URL: incognito_anonymizer-1.4.3-py3-none-any.whl
  • Upload date:
  • Size: 15.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.0 {"installer":{"name":"uv","version":"0.11.0","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

Hashes for incognito_anonymizer-1.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9ba6dc5330a6c0762c17f2e10098caddee5dfca07fc3cbed6a0b9ecb09dd161f
MD5 3e300b3064c77bc9c4af8ec8ea8c3ae9
BLAKE2b-256 3a5d1434316a5e4024bba6fd75a15880c2ab9d17eb2e450390cc9683760983cd

See more details on using hashes here.

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