X-Git-Url: https://code.communitydata.science/cdsc_reddit.git/blobdiff_plain/fc6575a28716f6d1611f988c48d15e64a22687ac..40d45637702fb51feb9f99ff7f6d71787af765ed:/submissions_2_parquet_part2.py?ds=sidebyside diff --git a/submissions_2_parquet_part2.py b/submissions_2_parquet_part2.py index 1708548..bd538e2 100644 --- a/submissions_2_parquet_part2.py +++ b/submissions_2_parquet_part2.py @@ -2,12 +2,8 @@ # spark script to make sorted, and partitioned parquet files -import pyspark from pyspark.sql import functions as f -from pyspark.sql.types import * -from pyspark import SparkConf, SparkContext -from pyspark.sql import SparkSession, SQLContext -import os +from pyspark.sql import SparkSession spark = SparkSession.builder.getOrCreate() @@ -31,12 +27,16 @@ df = df.withColumn("Day",f.dayofmonth(f.col("CreatedAt"))) df = df.withColumn("subreddit_hash",f.sha2(f.col("subreddit"), 256)[0:3]) # next we gotta resort it all. -df2 = df.sort(["subreddit","author","id","Year","Month","Day"],ascending=True) +df = df.repartition("subreddit") +df2 = df.sort(["subreddit","CreatedAt","id"],ascending=True) +df2 = df.sortWithinPartitions(["subreddit","CreatedAt","id"],ascending=True) df2.write.parquet("/gscratch/comdata/output/reddit_submissions_by_subreddit.parquet", partitionBy=["Year",'Month'], mode='overwrite') # # we also want to have parquet files sorted by author then reddit. -df3 = df.sort(["author","CreatedAt","subreddit","id","Year","Month","Day"],ascending=True) +df = df.repartition("author") +df3 = df.sort(["author","CreatedAt","id"],ascending=True) +df3 = df.sortWithinPartitions(["author","CreatedAt","id"],ascending=True) df3.write.parquet("/gscratch/comdata/output/reddit_submissions_by_author.parquet", partitionBy=["Year",'Month'], mode='overwrite') os.remove("/gscratch/comdata/output/reddit_submissions.parquet_temp")