开发者社区> 问答> 正文

PySpark-如何使用Pyspark计算每个字段的最小值,最大值?

我试图找到sql语句产生的每个字段的最小值,最大值,并将其写入csv文件。我试图以下面的方式得到结果。能否请你帮忙。我已经用python编写了,但现在尝试将其转换为pyspark直接在hadoop集群中运行

from pyspark.sql.functions import max, min, mean, stddev
from pyspark import SparkContext
sc =SparkContext()
from pyspark.sql import HiveContext
hive_context = HiveContext(sc)

bank = hive_context.table("cip_utilities.file_upload_temp")

data=hive_context.sql("select * from cip_utilities.cdm_variables_dict")
hive_context.sql("describe cip_utilities.cdm_variables_dict").registerTempTable("schema_def")
temp_data=hive_context.sql("select * from schema_def")
temp_data.show()
data1=hive_context.sql("select col_name from schema_def where data_type<>'string'")
colum_names_as_python_list_of_rows = data1.collect()

data1.show()

for line in colum_names_as_python_list_of_rows:

    #print value in MyCol1 for each row                
    ---Here i need to calculate min, max, mean etc for this particular field send by the for loop

展开
收起
社区小助手 2018-12-12 11:18:44 6876 0
1 条回答
写回答
取消 提交回答
  • 社区小助手是spark中国社区的管理员,我会定期更新直播回顾等资料和文章干货,还整合了大家在钉群提出的有关spark的问题及回答。

    您可以使用不同的功能查找最小值,最大值。这是使用agg函数获取dataframe列的这些细节的方法之一。

    from pyspark.sql.functions import *
    df = spark.table("HIVE_DB.HIVE_TABLE")
    df.agg(min(col("col_1")), max(col("col_1")), min(col("col_2")), max(col("col_2"))).show()
    但是,您还可以浏览描述和摘要(版本2.3以后)函数,以获取数据框中各列的基本统计信息。

    2019-07-17 23:20:03
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Apache Spark MLlib\'s Past Trajectory and New Directions 立即下载
Apache Spark MLlib's past traj 立即下载
LEARNINGS USING SPARK STREAMING & DATAFRAMES FOR WALMART SEARCH 立即下载