PyCharm搭建Spark開發(fā)環(huán)境實現(xiàn)第一個pyspark程序
一, PyCharm搭建Spark開發(fā)環(huán)境
Windows7, Java1.8.0_74, Scala 2.12.6, Spark 2.2.1, Hadoop2.7.6
通常情況下,Spark開發(fā)是基于Linux集群的,但這里作為初學(xué)者并且囊中羞澀,還是在windows環(huán)境下先學(xué)習(xí)吧。
參照這個配置本地的Spark環(huán)境。
之后就是配置PyCharm用來開發(fā)Spark。本人在這里浪費了不少時間,因為百度出來的無非就以下兩種方式:
1.在程序中設(shè)置環(huán)境變量
import os
import sys
os.environ['SPARK_HOME'] = 'C:\xxx\spark-2.2.1-bin-hadoop2.7'
sys.path.append('C:\xxx\spark-2.2.1-bin-hadoop2.7\python')
2.在Edit Configuration中添加環(huán)境變量


不過還是沒有解決程序中代碼自動補全。
想了半天,觀察到spark提供的pyspark很像單獨的安裝包,應(yīng)該可以考慮將pyspark包放到python的安裝目錄下,這樣也就自動添加到之前所設(shè)置的pythonpath里了,應(yīng)該就能實現(xiàn)pyspark的代碼補全提示。
將spark下的pyspark包放到python路徑下(注意,不是spark下的python?。?/p>


最后,實現(xiàn)了pyspark代碼補全功能。

二.第一個pyspark程序
作為小白,只能先簡單用下python+pyspark了。
數(shù)據(jù):Air Quality in Madrid (2001-2018)
需求:根據(jù)歷史數(shù)據(jù)統(tǒng)計出每個月平均指標值
import os
import re
from pyspark.sql import SparkSession
if __name__ == "__main__":
spark = SparkSession.builder.getOrCreate()
df_array = []
years = []
air_quality_data_folder = "C:/xxx/spark/air-quality-madrid/csvs_per_year"
for file in os.listdir(air_quality_data_folder):
if '2018' not in file:
year = re.findall("\d{4}", file)
years.append(year[0])
file_path = os.path.join(air_quality_data_folder, file)
df = spark.read.csv(file_path, header="true")
# print(df.columns)
df1 = df.withColumn('yyyymm', df['date'].substr(0, 7))
df_final = df1.filter(df1['yyyymm'].substr(0, 4) == year[0]).groupBy(df1['yyyymm']).agg({'PM10': 'avg'})
df_array.append(df_final)
pm10_months = [0] * 12
# print(range(12))
for df in df_array:
for i in range(12):
rows = df.filter(df['yyyymm'].contains('-'+str(i+1).zfill(2))).first()
# print(rows[1])
pm10_months[i] += (rows[1]/12)
years.sort()
print(years[0] + ' - ' + years[len(years)-1] + '年,每月平均PM10統(tǒng)計')
m_index = 1
for data in pm10_months:
print(str(m_index).zfill(2) + '月份: ' + '||' * round(data))
m_index += 1
運行結(jié)果:
- 2017年,每月平均PM10統(tǒng)計 01月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 02月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 03月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 04月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 05月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 06月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 07月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 08月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 09月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 10月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 11月份: |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 12月份: ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
由以上統(tǒng)計結(jié)果,可以看出4月份的PM10最低。
Done!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python 統(tǒng)計一個列表當中的每一個元素出現(xiàn)了多少次的方法
今天小編就為大家分享一篇python 統(tǒng)計一個列表當中的每一個元素出現(xiàn)了多少次的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11
Python基于回溯法子集樹模板解決旅行商問題(TSP)實例
這篇文章主要介紹了Python基于回溯法子集樹模板解決旅行商問題(TSP),簡單描述了旅行商問題并結(jié)合實例形式分析了Python使用回溯法子集樹模板解決旅行商問題的相關(guān)實現(xiàn)步驟與操作技巧,需要的朋友可以參考下2017-09-09
Python繪圖實現(xiàn)坐標軸共享與復(fù)用詳解
這篇文章主要為大家詳細介紹了Python在繪圖時如何實現(xiàn)坐標軸共享與復(fù)用,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02

