UDF小白入门


在PySpark中,使用UDF涉及有三个步骤:
前置:先创建一个spark dataframe

from pyspark.sql import SparkSession
from pyspark.sql.functions import *

spark = SparkSession.builder \
   .master("spark://localhost:7077") \
   .appName("pyspark sql demo") \
   .getOrCreate()

# 创建学生成绩DataFrame
studentDF = spark.createDataFrame(
    [
      ("张三", 85),
      ("李四", 90),
      ("王老五", 55)
    ],["name","score"]
)

studentDF.printSchema()
studentDF.show()

(1) 第一步是用Python语法创建一个函数并进行测试。

创建一个函数(普通的Python函数)将成绩转换到考察等级

def convertGrade(score):
    if score > 100:
        return "作弊"
    elif score >= 90:
        return "优秀"
    elif score >= 80:
        return "良好"
    elif score >= 70:
        return "中等"
    else:
        return "不及格"

(2) 第二步是通过将函数名传递给PySpark SQL的udf()函数来注册它。

#注册为一个UDF(在DataFrame API中使用时的注册方法)
convertGradeUDF = udf(convertGrade,StringType())

# 或者通过装饰器注册
@udf(StringType())
def convertGrade(score):
    if score > 100:
        return "作弊"
    elif score >= 90:
        return "优秀"
    elif score >= 80:
        return "良好"
    elif score >= 70:
        return "中等"
    else:
        return "不及格"

(3) 第三步是在DataFrame代码或发出SQL查询时使用UDF。在SQL查询中使用UDF时,注册过程略有不同。

# 使用该UDF将成绩转换为字母等级
studentDF \
  .withColumn("grade",convertGradeUDF(col("score"))) \
  .show()
'''

相关推荐

  1. UDF入门

    2024-04-23 01:08:05       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-23 01:08:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-23 01:08:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-23 01:08:05       82 阅读
  4. Python语言-面向对象

    2024-04-23 01:08:05       91 阅读

热门阅读

  1. git工具的安装及使用

    2024-04-23 01:08:05       37 阅读
  2. backtracking Leetcode 回溯算法题

    2024-04-23 01:08:05       28 阅读
  3. Linux文本处理三剑客:awk、grep和sed

    2024-04-23 01:08:05       40 阅读
  4. js高级 笔记03

    2024-04-23 01:08:05       32 阅读
  5. FastJson的使用

    2024-04-23 01:08:05       28 阅读
  6. 【程序设计与算法——C/C++入门】C语言入门

    2024-04-23 01:08:05       41 阅读
  7. 37-4 用Python编写SQL注入的基于错误报告的POC

    2024-04-23 01:08:05       37 阅读