Skip to main content

A Python package to read and write files in CDM format. Customized for SkyPoint use cases.

Project description

skypoint-python-cdm-connector

Python Spark CDM Connector by SkyPoint.

Apache Spark connector for the Microsoft Azure "Common Data Model". Reading and writing is supported and it is a work in progress. Please file issues for any bugs that you find.

For more information about the Azure Common Data Model, check out this page.

We support Azure Data Lake Service (ADLS) and AWS S3 as storage, historical data preservation using snapshots of the schema & data files and usage within PySpark, Azure Functions etc.

*Upcoming Support for incremental data refresh handling, [CDM 1.1](https://docs.microsoft.com/en-us/common-data-model/cdm-manifest and Google Cloud (Cloud Storage).

Example

  1. Please look into the sample usage file skypoint_python_cdm.py
  2. Dynamically add/remove entities, annotations and attributes
  3. Pass Reader and Writer object for any storage account you like to write/read data to/from.
  4. Check out the below code for basic read and write examples.
# Initialize empty model
m = Model()

# Sample dataframe
df = {"country": ["Brazil", "Russia", "India", "China", "South Africa", "ParaSF"],
       "currentTime": [datetime.now(), datetime.now(), datetime.now(), datetime.now(), datetime.now(), datetime.now()],
       "area": [8.516, 17.10, 3.286, 9.597, 1.221, 2.222],
       "capital": ["Brasilia", "Moscow", "New Dehli", "Beijing", "Pretoria", "ParaSF"],
       "population": [200.4, 143.5, 1252, 1357, 52.98, 12.34] }
df = pd.DataFrame(df)

# Generate entity from the dataframe
entity = Model.generate_entity(df, "customEntity")

# Add generated entity to model
m.add_entity(entity)

# Add model level annotation
# Annotation can be added at entity level as well as attribute level
Model.add_annotation("modelJsonAnnotation", "modelJsonAnnotationValue", m)


# Create an ADLSWriter to write into ADLS
writer = ADLSWriter("ACCOUNT_NAME", "ACCOUNT_KEY",
                     "CONTAINER_NAME", "STORAGE_NAME", "DATAFLOW_NAME")    

# Write data as well as model.json in ADLS storage
m.write_to_storage("customEntity", df, writer)

Contributing

This project welcomes contributions and suggestions.

References

Model.json version1 schema

A clean implementation for Python Objects from/to model.json file

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cdm-connector-0.0.6.70.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

cdm_connector-0.0.6.70-py3-none-any.whl (25.3 kB view details)

Uploaded Python 3

File details

Details for the file cdm-connector-0.0.6.70.tar.gz.

File metadata

  • Download URL: cdm-connector-0.0.6.70.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for cdm-connector-0.0.6.70.tar.gz
Algorithm Hash digest
SHA256 a8a8ab431a6e5a44bf4bef438b13ccc390c91a70d91b75b7dcd490809fda0b19
MD5 3fc95c65f9c080366a84ded82809e7ae
BLAKE2b-256 f96eb4595933644029689cd3cd32e2aab235b23d1de4506bc4a35f02901819aa

See more details on using hashes here.

File details

Details for the file cdm_connector-0.0.6.70-py3-none-any.whl.

File metadata

  • Download URL: cdm_connector-0.0.6.70-py3-none-any.whl
  • Upload date:
  • Size: 25.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for cdm_connector-0.0.6.70-py3-none-any.whl
Algorithm Hash digest
SHA256 48f7818c39275f747edc248e346c2c46d3e52980e2b1940312d05bb2b3c57e3b
MD5 5f857f68f1c8d92d6de7bf2cdb9c9782
BLAKE2b-256 6ebe1b88eb3282e14f1aa7e5dc8b3e82a8b58a446c1e2da5ad7e076979f76c37

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