Awesome Open Source
Awesome Open Source

Mimesis - Fake Data Generator

|

.. image:: https://raw.githubusercontent.com/lk-geimfari/mimesis/master/.github/images/readme-logo.png :target: https://github.com/lk-geimfari/mimesis

|

Description

.. image:: https://github.com/lk-geimfari/mimesis/workflows/test/badge.svg?branch=master :target: https://github.com/lk-geimfari/mimesis/actions :alt: Github Actions Test

.. image:: https://readthedocs.org/projects/mimesis/badge/?version=latest :target: https://mimesis.name/ :alt: Documentation Status

.. image:: https://codecov.io/gh/lk-geimfari/mimesis/branch/master/graph/badge.svg :target: https://codecov.io/gh/lk-geimfari/mimesis :alt: Code Coverage

.. image:: https://www.codefactor.io/repository/github/lk-geimfari/mimesis/badge :target: https://www.codefactor.io/repository/github/lk-geimfari/mimesis :alt: CodeFactor

.. image:: https://img.shields.io/pypi/v/mimesis?color=bright-green :target: https://pypi.org/project/mimesis/ :alt: PyPi Version

.. image:: https://img.shields.io/pypi/dm/mimesis
:target: https://pypi.org/project/mimesis/ :alt: PyPI - Downloads

.. image:: https://img.shields.io/badge/python-3.6+-brightgreen.svg :target: https://badge.fury.io/py/mimesis :alt: Python version

Mimesis is a high-performance fake data generator for Python, which provides data for a variety of purposes in a variety of languages. The fake data could be used to populate a testing database, create fake API endpoints, create JSON and XML files of arbitrary structure, anonymize data taken from production and etc.

Installation

To install mimesis, simply use pip:

.. code:: text

~ ⟩ pip install mimesis

Supported Features

  • Easy: Designed to be easy to use and learn.
  • Multilingual: Supports data for a lot of languages <https://mimesis.name/getting_started.html#locales>_.
  • Performance: The fastest <https://mimesis.name/foreword.html#performance>_ data generator available for Python.
  • Data variety: Supports a lot of data providers <https://mimesis.name/api.html>_ for a variety of purposes.
  • Country-specific data providers: Provides data specific only for some countries <https://mimesis.name/api.html#builtin-data-providers>_.
  • Extensibility: You can create your own data providers and use them with Mimesis.
  • Generic data provider: The simplified <https://mimesis.name/getting_started.html#generic-provider>_ access to all the providers from a single object.
  • Zero hard dependencies: Does not require any modules other than the Python standard library.
  • Schema-based generators: Provides an easy mechanism to generate data by the schema of any complexity.

Documentation

You can find the complete documentation on the Read the Docs <https://mimesis.name>_.

It is divided into several sections:

  • Foreword <https://mimesis.name/foreword.html>_
  • Getting Started <https://mimesis.name/getting_started.html>_
  • Tips and Tricks <https://mimesis.name/tips.html>_
  • API Reference <https://mimesis.name/api.html>_
  • Contributing <https://mimesis.name/contributing.html>_
  • Changelog <https://mimesis.name/changelog.html>_

You can improve it by sending pull requests to this repository.

Usage

This library is really easy to use and everything you need is just import an object which represents a type of data you need (we call such object a Provider).

In example below we import provider Person <https://mimesis.name/api.html#person>_, which represents data related to personal information, such as name, surname, email and etc:

.. code:: python

>>> from mimesis import Person
>>> person = Person('en')

>>> person.full_name()
'Brande Sears'

>>> person.email(domains=['mimesis.name'])
'[email protected]'

>>> person.email(domains=['mimesis.name'], unique=True)
'[email protected]'

>>> person.telephone(mask='1-4##-8##-5##3')
'1-436-896-5213'

More about the other providers you can read in our documentation_.

.. _documentation: https://mimesis.name/getting_started.html#providers

Locales

Mimesis currently includes support for 34 different locales_. You can specify a locale when creating providers and they will return data that is appropriate for the language or country associated with that locale.

Let's take a look how it works:

.. code:: python

>>> from mimesis import Person
>>> from mimesis.enums import Gender

>>> de = Person('de')
>>> en = Person('en')

>>> de.full_name(gender=Gender.FEMALE)
'Sabrina Gutermuth'

>>> en.full_name(gender=Gender.MALE)
'Layne Gallagher'

.. _locales: https://mimesis.name/getting_started.html#locales

Providers

Mimesis support over twenty different data providers available, which can produce data related to people, food, computer hardware, transportation, addresses, internet and more.

See API Reference <https://mimesis.name/getting_started.html#data-providers>_ for more info.

How to Contribute

  1. Take a look at contributing guidelines_.
  2. Check for open issues or open a fresh issue to start a discussion around a feature idea or a bug.
  3. Fork the repository on GitHub to start making your changes to the your_branch branch.
  4. Add yourself to the list of contributors_.
  5. Send a pull request and bug the maintainer until it gets merged and published.

.. _contributing guidelines: https://github.com/lk-geimfari/mimesis/blob/master/CONTRIBUTING.rst .. _contributors: https://github.com/lk-geimfari/mimesis/blob/master/CONTRIBUTORS.rst

Useful links

I have a Telegram channel where I daily post news, announces and all the open-source goodies I found, so subscribe: @the_art_of_development <https://t.me/the_art_of_development>_.

Thanks

Supported by JetBrains <https://www.jetbrains.com/?from=mimesis>_.

Disclaimer

The authors of Mimesis do not assume any responsibility for how you use it or how you use data generated with it. This library was designed with good intentions to make testing easier. Do not use the data generated with Mimesis for illegal purposes.

License

Mimesis is licensed under the MIT License. See LICENSE_ for more information.

.. _LICENSE: https://github.com/lk-geimfari/mimesis/blob/master/LICENSE


Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
python (54,384
json (1,190
testing (959
data (394
generator (347
mock (179
schema (178
fake (57
faker (41
synthetic-data (32
fixtures (26