Introdução ao PySpark
Benjamin Schmidt
Data Engineer
joined_df = large_df.join(broadcast(small_df),
on="key_column", how="inner")
joined_df.show()
# Usando explain() para ver o plano de execução
df.filter(df.Age > 40).select("Name").explain()
== Plano Físico ==
*(1) Filtro (isnotnull(Age) AND (Age > 30))
+- Scan ExistingRDD[Name:String, Age:Int]
df = spark.read.csv("large_dataset.csv", header=True, inferSchema=True) # Cache do DataFrame df.cache()# Realizar múltiplas operações no DataFrame em cache df.filter(df["column1"] > 50).show() df.groupBy("column2").count().show()
# Persistir o DataFrame com nível de armazenamento from pyspark import StorageLevel df.persist(StorageLevel.MEMORY_AND_DISK)# Realizar transformações result = df.groupBy("column3").agg({"column4": "sum"}) result.show() # Despersistir após o uso df.unpersist()
map() a groupby() pela seletividadeIntrodução ao PySpark