【发布时间】:2017-12-15 14:22:02
【问题描述】:
我需要一次计算多个数据帧列的 md5 哈希。
功能
def md5 = udf((s: String) => toHex(MessageDigest.getInstance("MD5").digest(s.getBytes("UTF-8"))))
def toHex(bytes: Array[Byte]): String = bytes.map("%02x".format(_)).mkString("")
以一列为例
var test_df = load_df.as('a).select($"a.attr1", md5($"a.attr2").as("hash_key"))
+-------------+--------------------+
| attr1 | hash_key|
+-------------+--------------------+
|9/1/2015 0:23|7a2f516dad8f13ae1...|
|9/1/2015 0:31|339c72b1870c3a6be...|
|9/1/2015 0:19|7065847af7abc6bce...|
|9/1/2015 1:32|38c7276958809893b...|
一列 (a.attr2) 的生成效果很好,但我找不到任何将多列插入/连接到 md5() 函数中的好方法。
【问题讨论】:
标签: scala apache-spark dataframe md5 user-defined-functions