-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path0_DE_data_prep.py
executable file
·44 lines (35 loc) · 1.26 KB
/
0_DE_data_prep.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#Fetch raw data and create an external Hive table in CDP/CML.
#Data taken from http://...WineNewGBTDataSet.csv
#wget http://.../WineNewGBTDataSet.csv; aws s3 cp WineNewGBTDataSet.csv s3://ml-field/demo/wine/; rm WineNewGBTDataSet.csv
from pyspark.sql import SparkSession
from pyspark.sql.types import Row, StructField, StructType, StringType, IntegerType
spark = SparkSession.builder\
.appName("Setup Wine Table")\
.config("spark.yarn.access.hadoopFileSystems","s3a://ml-field/demo/wine/")\
.getOrCreate()
spark.sql("SHOW databases").show()
spark.sql("USE default")
spark.sql("SHOW tables").show()
#spark.sql("DROP TABLE IF EXISTS wine").show()
statement = '''
CREATE EXTERNAL TABLE IF NOT EXISTS `default`.`wine` (
`fixedAcidity` double ,
`volatileAcidity` double ,
`citricAcid` double ,
`residualSugar` double ,
`chlorides` double ,
`freeSulfurDioxide` double ,
`totalSulfurDioxide` double ,
`density` double ,
`pH` double ,
`sulphates` double ,
`Alcohol` double ,
`Quality` string )
ROW FORMAT DELIMITED FIELDS TERMINATED BY ';'
STORED AS TextFile
LOCATION 's3a://ml-field/demo/wine/'
'''
spark.sql(statement)
spark.sql("DESCRIBE TABLE EXTENDED `default`.`wine`").show()
spark.sql("SELECT * FROM `default`.`wine` LIMIT 5").take(5)
spark.stop()