Skip to content

Latest commit

 

History

History
76 lines (58 loc) · 2.63 KB

15_python.md

File metadata and controls

76 lines (58 loc) · 2.63 KB

Documentation

PySpark with Data Frames

With the inclusion of the Cassandra Data Source, PySpark can now be used with the Connector to access Cassandra data. This does not require DataStax Enterprise but you are limited to DataFrame only operations.

Setup

To enable Cassandra access the Spark Cassandra Connector assembly jar must be included on both the driver and executor classpath for the PySpark Java Gateway. This can be done by starting the PySpark shell similarly to how the spark shell is started. The preferred method is now to use the Spark Packages website. https://spark-packages.org/package/datastax/spark-cassandra-connector

./bin/pyspark \
  --packages com.datastax.spark:spark-cassandra-connector_2.11:2.3.2

Loading a DataFrame in Python

A DataFrame can be created which links to Cassandra by using the the org.apache.spark.sql.cassandra source and by specifying keyword arguments for keyspace and table.

Example Loading a Cassandra Table as a Pyspark DataFrame

 spark.read\
    .format("org.apache.spark.sql.cassandra")\
    .options(table="kv", keyspace="test")\
    .load().show()
+-+-+
|k|v|
+-+-+
|5|5|
|1|1|
|2|2|
|4|4|
|3|3|
+-+-+

Saving a DataFrame in Python to Cassandra

A DataFrame can be saved to an existing Cassandra table by using the the org.apache.spark.sql.cassandra source and by specifying keyword arguments for keyspace and table and saving mode (append, overwrite, error or ignore, see Data Sources API doc).

Example Saving to a Cassanra Table as a Pyspark DataFrame

 df.write\
    .format("org.apache.spark.sql.cassandra")\
    .mode('append')\
    .options(table="kv", keyspace="test")\
    .save()

The options and parameters are identical to the Scala Data Frames Api so please see Data Frames for more information.

Passing options with periods to the DataFrameReader

Python does not support using periods(".") in variable names. This makes it slightly more difficult to pass SCC options to the DataFrameReader. The options function takes kwargs** which means you can't directly pass in keys. There is a workaround though. Python allows you to pass a dictionary as a representation of kwargs and dictionaries can have keys with periods.

Example of using a dictionary as kwargs

load_options = { "table": "kv", "keyspace": "test", "spark.cassandra.input.split.size_in_mb": "10"}
spark.read.format("org.apache.spark.sql.cassandra").options(**load_options).load().show()

Next - Spark Partitioners