CData Python Connector for Elasticsearch

Build 24.0.9060

From Petl

The connector can be used to create ETL applications and pipelines for CSV data in Python using Petl.

Install Required Modules

Install the Petl modules using the pip utility.
pip install petl

Connecting

After you import the modules, including the CData Python Connector for Elasticsearch, you can use the connector's connect function to create a connection using a valid Elasticsearch connection string. If you prefer not to use a direct connection, you can use a SQLAlchemy engine.
import petl as etl
import cdata.elasticsearch as mod
cnxn = mod.connect("Server=127.0.0.1;Port=9200;")

Extract, Transform, and Load the Elasticsearch Data

Create a SQL query string and store the query results in a DataFrame.
sql = "SELECT	Id, Name FROM [CData].[Elasticsearch].Employee "
table1 = etl.fromdb(cnxn,sql)

Loading Data

With the query results stored in a DataFrame, you can load your data into any supported Petl destination. The following example loads the data into a CSV file.
etl.tocsv(table1,'output.csv')

Modifying Data

Insert new rows into Elasticsearch tables using Petl's appenddb function.
table1 = [['Id','Name'],['Jon Doe','Floppy Disks']]
etl.appenddb(table1,cnxn,'[CData].[Elasticsearch].Employee')

Copyright (c) 2024 CData Software, Inc. - All rights reserved.
Build 24.0.9060