web-dev-qa-db-fra.com

Comment remplacer conditionnellement la valeur d'une colonne en fonction de l'évaluation d'une expression basée sur une autre colonne de Pyspark?

import numpy as np

df = spark.createDataFrame(
    [(1, 1, None),
     (1, 2, float(5)),
     (1, 3, np.nan),
     (1, 4, None),
     (0, 5, float(10)),
     (1, 6, float('nan')),
     (0, 6, float('nan'))],
    ('session', "timestamp1", "id2"))
+-------+----------+----+
|session|timestamp1| id2|
+-------+----------+----+
|      1|         1|null|
|      1|         2| 5.0|
|      1|         3| NaN|
|      1|         4|null|
|      0|         5|10.0|
|      1|         6| NaN|
|      0|         6| NaN|
+-------+----------+----+

Comment remplacer la valeur de la colonne timestamp1 par la valeur 999 lorsque session == 0?

Résultat attendu

+-------+----------+----+
|session|timestamp1| id2|
+-------+----------+----+
|      1|         1|null|
|      1|         2| 5.0|
|      1|         3| NaN|
|      1|         4|null|
|      0|       999|10.0|
|      1|         6| NaN|
|      0|       999| NaN|
+-------+----------+----+

Est-il possible de le faire en utilisant replace () dans PySpark?

17
GeorgeOfTheRF

Vous devriez utiliser la fonction when (avec otherwise):

from pyspark.sql.functions import when

targetDf = df.withColumn("timestamp1", \
              when(df["session"] == 0, 999).otherwise(df["timestamp1"]))
38
Assaf Mendelson