avro-to-python-etp


Nameavro-to-python-etp JSON
Version 1.0.4 PyPI version JSON
download
home_pagehttps://github.com/geosiris-technologies/avro-to-python-etp
SummaryLight tool for compiling avro schema files (.avsc) to python classes making using avro schemata easy.
upload_time2023-11-07 23:05:11
maintainer
docs_urlNone
authorScott Rothbarth
requires_python>=3.8,<4.0
licenseMIT
keywords avro etp
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ==================
avro-to-python-etp
==================

avro-to-python-etp is a light tool for compiling avro schema files (.avsc) to python classes making using avro schemata easy.


* Free software: MIT license
* Documentation: https://avro-to-python-etp.readthedocs.io.

Installation
^^^^^^^^^^^^

Pip install (recommended)
-------------------------
To install avro-to-python-etp, run this command in your terminal:

.. code-block:: console

    $ pip install avro-to-python-etp

Install From Source ()
----------------------

The sources for avro-to-python-etp can be downloaded source as well.

Clone the public repository:

.. code-block:: console

    $ git clone git://github.com/srserves85/avro-to-python-etp


Once you have a copy of the source, you can install it with:


.. code-block:: console

    $ python setup.py install

or

.. code-block:: console

    $ pip install -e .


Examples
^^^^^^^^

Majority of the use of avro-to-python-etp is assumed to be used as a cli, but you can still import and use the python classes under the hood as well.

CLI (without --pip)
-------------------
To use the cli, here is the available cli commands:

.. code-block:: bash

    avro-to-python-etp [source] [target]
        Options:
            --pip TEXT              make package pip installable using this name
            --author TEXT           author name of the pip installable package
            --package_version TEXT  version of the pip intallable package  [default: 0.1.0]
            --help                  Show this message and exit


The above will compile the avsc files and convert the to python classes found in [path_to_target_directory]

An example of doing this is the following:

.. code-block:: bash

    avro-to-python-etp [path_to_source_avsc_files] [path_to_target_directory]


If you run the above on a valid avro avsc file, you should then be able to import them as you would in the avro idl namespace Here is an example of a single avsc record from the namespace: *name.space* and name: *RecordClass*:

.. code-block:: python

    from name.space import RecordClass

    record = RecordClass({'foo': True, 'bar': 'true', 'baz': 10, 'food': 'CHOCOLATE'})


CLI (with --pip)
----------------
You can also choose to make compiled avro packages ***pip installable*** by adding the "--pip" flags. An example of this is the following:
.. code-block:: bash

    avro-to-python-etp [path_to_source_avsc_files] [path_to_target_directory] --pip test_avro

By running this, you should be able to pip install the above package you created from the target directory you specified by running:

.. code-block:: bash

    pip install -e path_to_target_directory

Now that you have the package installed, you can import it by it's package name and namespace. Here is the same example of the same avsc from above, only with a pip package of *test_avro*:

.. code-block:: python

    from test_avro.name.space import RecordClass

    record = RecordClass({'foo': True, 'bar': 'true', 'baz': 10, 'food': 'CHOCOLATE'})


avro-to-python-etp in a Script
------------------------------
You can also use the reader and writer packages in avro-to-python-etp as you would any other python package. Avro to python is split between a *reader* and *writer* classes. avro-to-python-etp treates namespaces as acyclic trees and uses depth first search to ensure no duplication or namespace collisions on read and write. An example useage is below:

.. code-block:: python

    from avro_to_python.reader import AvscReader
    from avro_to_python.writer import AvroWriter

    # initialize the reader object
    reader = AvscReader(directory='tests/avsc/records/')

    # generate the acyclic tree object
    reader.read()

    # initialize the writer object
    writer = AvroWriter(reader.file_tree, pip='test_pip')

    # compile python files using 'tests/test_records as the namespace root'
    writer.write(root_dir='tests/test_records')



Roadmap
^^^^^^^

Reader

- [X] Create Namespace Trees on nested namespaces
- [X] Read Record and Enum File
- [X] Primitive types
- [X] Array Types
- [X] Union types
- [X] References to other files
- [X] Map Types
- [ ] Logical Types (Currently just converts to primitive types)

Writer

- [X] Base Schema Writer
- [X] Base Record Schema
- [X] Base Enum Schema
- [X] Primitive Types Schema
- [X] Array Types Schema
- [X] Union Types Schema
- [X] Map Types
- [ ] Logical Types Schema (Currently just converts to primitive types)
- [X] Add configs to pip install package

CLI

- [X] Wrap Writer and Reader into one cli commmit
- [X] Add pip install option (would include all files to pip install compiled package)
- [ ] Add better --help documentation

Documentation

- [ ] Document reader class
- [ ] Document writer class
- [ ] Document cli
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/geosiris-technologies/avro-to-python-etp",
    "name": "avro-to-python-etp",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8,<4.0",
    "maintainer_email": "",
    "keywords": "avro,etp",
    "author": "Scott Rothbarth",
    "author_email": "srserves85@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/60/dd/3ba7342e866ed01dc0306b1567e3ad5084d879de135b4fb4f0702f5511ec/avro_to_python_etp-1.0.4.tar.gz",
    "platform": null,
    "description": "==================\navro-to-python-etp\n==================\n\navro-to-python-etp is a light tool for compiling avro schema files (.avsc) to python classes making using avro schemata easy.\n\n\n* Free software: MIT license\n* Documentation: https://avro-to-python-etp.readthedocs.io.\n\nInstallation\n^^^^^^^^^^^^\n\nPip install (recommended)\n-------------------------\nTo install avro-to-python-etp, run this command in your terminal:\n\n.. code-block:: console\n\n    $ pip install avro-to-python-etp\n\nInstall From Source ()\n----------------------\n\nThe sources for avro-to-python-etp can be downloaded source as well.\n\nClone the public repository:\n\n.. code-block:: console\n\n    $ git clone git://github.com/srserves85/avro-to-python-etp\n\n\nOnce you have a copy of the source, you can install it with:\n\n\n.. code-block:: console\n\n    $ python setup.py install\n\nor\n\n.. code-block:: console\n\n    $ pip install -e .\n\n\nExamples\n^^^^^^^^\n\nMajority of the use of avro-to-python-etp is assumed to be used as a cli, but you can still import and use the python classes under the hood as well.\n\nCLI (without --pip)\n-------------------\nTo use the cli, here is the available cli commands:\n\n.. code-block:: bash\n\n    avro-to-python-etp [source] [target]\n        Options:\n            --pip TEXT              make package pip installable using this name\n            --author TEXT           author name of the pip installable package\n            --package_version TEXT  version of the pip intallable package  [default: 0.1.0]\n            --help                  Show this message and exit\n\n\nThe above will compile the avsc files and convert the to python classes found in [path_to_target_directory]\n\nAn example of doing this is the following:\n\n.. code-block:: bash\n\n    avro-to-python-etp [path_to_source_avsc_files] [path_to_target_directory]\n\n\nIf you run the above on a valid avro avsc file, you should then be able to import them as you would in the avro idl namespace Here is an example of a single avsc record from the namespace: *name.space* and name: *RecordClass*:\n\n.. code-block:: python\n\n    from name.space import RecordClass\n\n    record = RecordClass({'foo': True, 'bar': 'true', 'baz': 10, 'food': 'CHOCOLATE'})\n\n\nCLI (with --pip)\n----------------\nYou can also choose to make compiled avro packages ***pip installable*** by adding the \"--pip\" flags. An example of this is the following:\n.. code-block:: bash\n\n    avro-to-python-etp [path_to_source_avsc_files] [path_to_target_directory] --pip test_avro\n\nBy running this, you should be able to pip install the above package you created from the target directory you specified by running:\n\n.. code-block:: bash\n\n    pip install -e path_to_target_directory\n\nNow that you have the package installed, you can import it by it's package name and namespace. Here is the same example of the same avsc from above, only with a pip package of *test_avro*:\n\n.. code-block:: python\n\n    from test_avro.name.space import RecordClass\n\n    record = RecordClass({'foo': True, 'bar': 'true', 'baz': 10, 'food': 'CHOCOLATE'})\n\n\navro-to-python-etp in a Script\n------------------------------\nYou can also use the reader and writer packages in avro-to-python-etp as you would any other python package. Avro to python is split between a *reader* and *writer* classes. avro-to-python-etp treates namespaces as acyclic trees and uses depth first search to ensure no duplication or namespace collisions on read and write. An example useage is below:\n\n.. code-block:: python\n\n    from avro_to_python.reader import AvscReader\n    from avro_to_python.writer import AvroWriter\n\n    # initialize the reader object\n    reader = AvscReader(directory='tests/avsc/records/')\n\n    # generate the acyclic tree object\n    reader.read()\n\n    # initialize the writer object\n    writer = AvroWriter(reader.file_tree, pip='test_pip')\n\n    # compile python files using 'tests/test_records as the namespace root'\n    writer.write(root_dir='tests/test_records')\n\n\n\nRoadmap\n^^^^^^^\n\nReader\n\n- [X] Create Namespace Trees on nested namespaces\n- [X] Read Record and Enum File\n- [X] Primitive types\n- [X] Array Types\n- [X] Union types\n- [X] References to other files\n- [X] Map Types\n- [ ] Logical Types (Currently just converts to primitive types)\n\nWriter\n\n- [X] Base Schema Writer\n- [X] Base Record Schema\n- [X] Base Enum Schema\n- [X] Primitive Types Schema\n- [X] Array Types Schema\n- [X] Union Types Schema\n- [X] Map Types\n- [ ] Logical Types Schema (Currently just converts to primitive types)\n- [X] Add configs to pip install package\n\nCLI\n\n- [X] Wrap Writer and Reader into one cli commmit\n- [X] Add pip install option (would include all files to pip install compiled package)\n- [ ] Add better --help documentation\n\nDocumentation\n\n- [ ] Document reader class\n- [ ] Document writer class\n- [ ] Document cli",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Light tool for compiling avro schema files (.avsc) to python classes making using avro schemata easy.",
    "version": "1.0.4",
    "project_urls": {
        "Homepage": "https://github.com/geosiris-technologies/avro-to-python-etp",
        "Repository": "https://github.com/geosiris-technologies/avro-to-python-etp"
    },
    "split_keywords": [
        "avro",
        "etp"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "82496d0c38d197a0fd000588d400c94170fdb18cd5a7852b5de5dc9bfdb2bc96",
                "md5": "65b897480c998bc3e660fc9e76287d6b",
                "sha256": "90afd39e50e37697cd8d1be06597eb6b3ac4e1ab4567ae0074d7a24a6cde8aa2"
            },
            "downloads": -1,
            "filename": "avro_to_python_etp-1.0.4-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "65b897480c998bc3e660fc9e76287d6b",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8,<4.0",
            "size": 42969,
            "upload_time": "2023-11-07T23:05:09",
            "upload_time_iso_8601": "2023-11-07T23:05:09.875131Z",
            "url": "https://files.pythonhosted.org/packages/82/49/6d0c38d197a0fd000588d400c94170fdb18cd5a7852b5de5dc9bfdb2bc96/avro_to_python_etp-1.0.4-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "60dd3ba7342e866ed01dc0306b1567e3ad5084d879de135b4fb4f0702f5511ec",
                "md5": "94883de0f3d1d0c3e54d5ed51c2fcede",
                "sha256": "b96d934064b2c8a43eded39ce21832cbe731763da7efe0d9504db0463c56bcaa"
            },
            "downloads": -1,
            "filename": "avro_to_python_etp-1.0.4.tar.gz",
            "has_sig": false,
            "md5_digest": "94883de0f3d1d0c3e54d5ed51c2fcede",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8,<4.0",
            "size": 26125,
            "upload_time": "2023-11-07T23:05:11",
            "upload_time_iso_8601": "2023-11-07T23:05:11.513462Z",
            "url": "https://files.pythonhosted.org/packages/60/dd/3ba7342e866ed01dc0306b1567e3ad5084d879de135b4fb4f0702f5511ec/avro_to_python_etp-1.0.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-11-07 23:05:11",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "geosiris-technologies",
    "github_project": "avro-to-python-etp",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "tox": true,
    "lcname": "avro-to-python-etp"
}
        
Elapsed time: 0.41451s