Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/EDS-APHP-legacy/pySyntheticDatasetGenerator
Generate relational fictive dataset from a simple yaml description
https://github.com/EDS-APHP-legacy/pySyntheticDatasetGenerator
data-generator database faker generator synthetic-data
Last synced: about 2 months ago
JSON representation
Generate relational fictive dataset from a simple yaml description
- Host: GitHub
- URL: https://github.com/EDS-APHP-legacy/pySyntheticDatasetGenerator
- Owner: EDS-APHP-legacy
- License: gpl-3.0
- Created: 2017-03-27T12:10:21.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2019-04-24T18:48:30.000Z (over 5 years ago)
- Last Synced: 2024-11-08T04:03:18.385Z (2 months ago)
- Topics: data-generator, database, faker, generator, synthetic-data
- Language: Python
- Homepage:
- Size: 716 KB
- Stars: 4
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-data-synthesis - pySyntheticDatasetGenerator - Generate relational fictive dataset from a simple yaml description (Process-driven methods / Tabular)
README
# SyntheticDatasetGenerator
## Dependencies
```
pip install -r requirements.txt
```
- python >=3.6
- liquibase in the path (in case documentation generation needed)
- postgresql database (in case both documentation & data loaded needed)## Run
1. Push your base file into input
1. Fill config/sdgen.yaml
1. Run make clean run ddl## Install
```
make
```## Test
```
make test
```## Principle
# Goal
- input:
- a config file in yaml
- csv files already existing (eg: terminologies)
- output:
- one ore multiple data csv reproductible# Csv Format (input & output)
Csv must respect:
- encoding: utf-8
- separator: ";"
- quote: False
- header: None
- date format: "%Y-%M-%d"
- datetime format: "%Y-%M-%d %H:%m:%s"
- strings must not contain the separator (";")# Table
- Primary Keys: each table must have an integer primary key
- Foreign Keys: they must refer a primary key.# Yaml Configuration
- Table
- existing table must have a "input" defined
- generated table must not have "input" defined
- Fields Class
- sequence: an autoincrement from 1 to "table.tableSize"
- simple (percentNull)
- integer (begin, end)
- bigint (begin, end)
- date (begin, end)
- time (begin, end)
- varchar (begin, end)
- regexp (pattern)
- real (begin, end, decimal)
- lookup (fk, table, field)# Data Type
- DBC Type Java Type
- CHAR String
- VARCHAR String
- LONGVARCHAR String
- NUMERIC java.math.BigDecimal
- DECIMAL java.math.BigDecimal
- BIT boolean
- BOOLEAN boolean
- TINYINT byte
- SMALLINT short
- INTEGER int
- BIGINT long
- REAL float
- FLOAT double
- DOUBLE double
- BINARY byte[]
- VARBINARY byte[]
- LONGVARBINARY byte[]
- DATE java.sql.Date
- TIME java.sql.Time
- TIMESTAMP java.sql.Timestamp
- CLOB Clob
- BLOB Blob
- ARRAY Array
- DISTINCT mapping of underlying type
- STRUCT Struct
- REF Ref
- DATALINK java.net.URL
- JAVA_OBJECT underlying Java class# Generate schema
```
make load doc
```