是的,这是可能的。您应该创建 udf 负责从映射中过滤键并将其与 withColumn 转换一起使用以过滤来自 collection 字段的键。
以下 Scala 中的示例实现:
// Start from implementing method in Scala responsible for filtering keys from Map
def filterKeys(collection: Map[String, String], keys: Iterable[String]): Map[String, String] =
collection.filter{case (k,_) => !keys.exists(_ == k)}
// Create Spark UDF based on above function
val filterKeysUdf = udf((collection: Map[String, String], keys: Iterable[String]) => filterKeys(collection, keys))
// Use above udf to filter keys
val newDf = df.withColumn("collection", filterKeysUdf(df("collection"), lit(Array("k1"))))
在 Python 中的实现:
# Start from implementing method in Python responsible for filtering keys from dict
def filterKeys(collection, keys):
return {k:collection[k] for k in collection if k not in keys}
# Create Spark UDF based on above function
filterKeysUdf = udf(filterKeys, MapType(StringType(), StringType()))
# Create array literal based on Python list
keywords_lit = array(*[lit(k) for k in ["k1","k2"]])
# Use above udf to filter keys
newDf = df.withColumn("collection", filterKeysUdf(df.collection, keywords_lit))