Skip to main content

Command line tool to generate anonymised demonstrator data

Project description

Exhibit: Command line tool to create anonymised demonstrator data

The goal of Exhibit is to make it easier to generate synthethic data at scale in a controlled and reproducible way.


main

Build Status CodeQL codecov

latest

Build Status CodeQL codecov

Key features

  • Control all aspects of the anonymisation process: which columns to anonymise and to what degree
  • Rapidly iterate on the anonymisation options
  • Set categorical weights to create custom distributions
  • Use regular expressions to bulk-anonymise identifiers
  • Add columns derived from newly anonymised data
  • Preserve important relationships between your columns (paired, hierarchical, custom)
  • Add outliers to any subset of the generated data
  • Generate and manipulate missing data and timeseries
  • Generate geo-spatial data using H3 hexes
  • Augment your synthetic data with compiled machine learning models and custom functions
  • Use SQL to generate conditional values based on external tables

Installation:

To install using pip, enter the following command at a Bash or Windows command prompt:

pip install exhibit

Alternatively, download or clone the repository and run pip install . from the root folder.

Quickstart

Exhibit has two principal modes of operation:

  • fromdata produces a detailed, user-editable .yml specification
  • fromspec which produces the anonymised dataset from the supplied specification

See the -h listing for the full list of optional command line parameters.

The repository includes a few sample datasets and specifications.
You can find them in exhibit/sample/_data and exhibit/sample/_spec

To create a demo dataset, run:
exhibit fromspec exhibit/sample/_spec/inpatients_demo.yml -o demo.csv

To create a demo specification that equialises all probabilities and weights, run:
exhibit fromdata exhibit/sample/_data/inpatients.csv -ew -o demo.yml

Database

Exhibit is bundled with a SQLite3 database and a Python utility tool to interact with it. Alternatively, you can connect directly to /exhbit/db/exhibit.db. The database contains three sample aliasing datasets: mountains, birds and patients designed to help you quickly alias original values without manually editing individual column values.

  • mountains has 15 mountain ranges and their top 10 peaks making it useful for aliasing hierarchical pairs, like NHS Boards and Hospitals.
  • birds has 150 pairs of common / scientific bird names. This can be useful for 1:1 paired columns.
  • patients has 360 made-up patient records with details such as gender, 5-year age band, date of birth and CHI number. Fields from this dataset can be selectively pulled in when linked data is required.
  • dates has dates ranging from 1900-01-01 to 2100-01-01 at a single day interval. This table is useful if you have a SQL statement in the anonymising_set that picks dates based on a condition.

The database is also used to store temporary data for columns where the number of unique values exceeds user threshold and thus not available for editing directly in the yml file.

Note that original, confidential data might be saved in the exhibit/db/exhibit.db file on your local machine. You can purge all temporary tables by calling --purge command from the included utility tool or by interfacing with the database directly.

Disclaimer

Please note that the degree of anonymisation for each dataset produced by the tool will depend heavily on user choices in the specification. As such, there is no guarantee that confidential data will be suitably masked under all scenarios. If you intend to work with sensitive data, make sure to thoroughly evaluate the output before making it public.

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

exhibit-0.9.9.tar.gz (870.0 kB view details)

Uploaded Source

Built Distribution

exhibit-0.9.9-py3-none-any.whl (904.0 kB view details)

Uploaded Python 3

File details

Details for the file exhibit-0.9.9.tar.gz.

File metadata

  • Download URL: exhibit-0.9.9.tar.gz
  • Upload date:
  • Size: 870.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.11

File hashes

Hashes for exhibit-0.9.9.tar.gz
Algorithm Hash digest
SHA256 6d0ca635ae1a9e7e5a9aabdc887b749e6a5e530fd248adeba9ebb4b69e20bd05
MD5 c4a265a303b17e63f90f9ca9a392696d
BLAKE2b-256 5b3881f5bc1c83c469f48a3daaaffd814be10a0ba5a6cb38870b9acaaa8ba9fc

See more details on using hashes here.

File details

Details for the file exhibit-0.9.9-py3-none-any.whl.

File metadata

  • Download URL: exhibit-0.9.9-py3-none-any.whl
  • Upload date:
  • Size: 904.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.11

File hashes

Hashes for exhibit-0.9.9-py3-none-any.whl
Algorithm Hash digest
SHA256 245708e89782853cbc55d61a3b808fafb772cc5e3f63851c8763504e934e98ad
MD5 3660f53c77f99dc5a500002f1050f476
BLAKE2b-256 e1a821c5f0d8edf20aefc05fa4564160d253af51ba7c81b37c7afb76dfb1da30

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