Data opschonen met PySpark
Mike Metzger
Data Engineering Consultant
DataFrames:
# Geef rijen terug waar name met "M" begint voter_df.filter(voter_df.name.like('M%'))# Geef alleen name en position terug voters = voter_df.select('name', 'position')
voter_df.filter(voter_df.date > '1/1/2019') # of voter_df.where(...)
voter_df.select(voter_df.name)
voter_df.withColumn('year', voter_df.date.year)
voter_df.drop('unused_column')
~voter_df.filter(voter_df['name'].isNotNull())
voter_df.filter(voter_df.date.year > 1800)
voter_df.where(voter_df['_c0'].contains('VOTE'))
voter_df.where(~ voter_df._c1.isNull())
import pyspark.sql.functions as F
voter_df.withColumn('upper', F.upper('name'))
voter_df.withColumn('splits', F.split('name', ' '))
voter_df.withColumn('year', voter_df['_c4'].cast(IntegerType()))
Diverse hulpfuncties/transformaties voor ArrayType()
.size(<column>) - geeft de lengte van een ArrayType()-kolom
.getItem(<index>) - haalt het item op op de gegeven index van een lijstkolom
Data opschonen met PySpark