Skip to main content

Random data generator for the command line

Project description

https://beerpay.io/l-x/fakr/badge.svg?style=beer https://badges.gitter.im/random-data-fakrs/Lobby.svg https://travis-ci.org/l-x/fakr.svg?branch=master https://codecov.io/gh/l-x/fakr/branch/master/graph/badge.svg

Random data, fakrs!

fakr reads a Jinja2 Template from stdin, renders it using a vocabulary and writes the result to stdout. It’s as simple as that…

Installation

$ pip install fakr

Basic Usage

$ fakr --help

Examples

Generate a simple csv file with 100k rows

$ echo "{{row}},{{row%100}},{{firstname}},{{lastname}},{{email}}" \
  | fakr --count 100000``

Use a file for complex template

$ cat examples/templates/vcard.tpl \
  | fakr --count 1000

Make a http request using curl:

$ echo "company={{company|urlencode}}&city={{city|urlencode}}"  \
  | fakr -c1 \
  | curl httpbin.org/post -d @-

Write data to a redis server:

$ echo 'firstname \"{{firstname}}\" lastname \"{{lastname}}\" email \"{{email}}\"' \
  | fakr \
  | xargs -i redis-cli HMSET {}``

Templates

The templates you use for data generation are plain Jinja2 Templates. See their reference for detailed information.

There are a few custom filters, functions and variables for use with fakr:

Custom filters:

  • ascii: Converts the value to ascii (using Unidecode) (i. e. {{lastname|ascii}})

  • shuffle: Shuffles the value randomly (i. e. {{lastname|shuffle}})

  • chance: Gives the value a chance from 0.0 to 1.0 to be returned (i. e. {{firstname|chance(0.9)}} - firstname will be 90% returned, 10% empty)

  • rjust: Right-justifies the value to the given with (i. e. {{company|rjust(40)}})

  • ljust: Left-justifies the value to the given with (i. e. {{company|ljust(40)}})

  • center: Centers the value in width (i. e. {{company|center(40)}})

  • hash: Calculates the hash with a given hashing algo (i. e. {{email|hash(‘md5’)}})

Custom functions:

  • translate

  • uuid4: Returns a new UUIDv4 on every call (i. e. {{uuid4()}})

  • unixtime: Returns a the current unixtime as float in seconds, (i. e. {{unixtime()}})

Fixed (vocabulary independent) variables:

  • row: The row (starting from 0) of the current dataset

  • id: The id or sequence number of the current dataset

  • guid: The representation of the id in a uuid-like fashion

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

fakr-0.1.1.tar.gz (78.6 kB view details)

Uploaded Source

Built Distribution

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

fakr-0.1.1-py3-none-any.whl (78.5 kB view details)

Uploaded Python 3

File details

Details for the file fakr-0.1.1.tar.gz.

File metadata

  • Download URL: fakr-0.1.1.tar.gz
  • Upload date:
  • Size: 78.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for fakr-0.1.1.tar.gz
Algorithm Hash digest
SHA256 7ed7b2acb1961673c9433cf8b3558348a424cec86e7b5f45ff11d2cdafa3ebf9
MD5 eb4c86e92f3ca84714db3847541251fd
BLAKE2b-256 6a1d244c8813fd3e2fd17a94560e89a882977f29ea95d3d7c8e32f15f5d1fd71

See more details on using hashes here.

File details

Details for the file fakr-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: fakr-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 78.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for fakr-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a24fe9da1263db515ba41d6a08f2f842bdb2ac1872f57201beed48ed4974bc85
MD5 a20f92f88bbd2a84408c3555097ace68
BLAKE2b-256 08d8b7a88d05b8bac73d4c2de881cc87b421a9f228fe582acd9163aeed6d5757

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