当前位置: 首页 > article >正文

数据处理生产环境_利用MurmurHash3算法在Spark和Scala中生成随机颜色

需求

        根据给定的轨迹编号在这一列后面生成随机颜色_16

输入数据

("吃饭", "123"),
("吃饭", "宋江"),
("郭靖", "宋江"),
("杨过", "奥特曼"),
("周芷若", "张无忌"),
("石破天", "谢逊"),
("赵敏", "张三丰"),
("小龙女", "杨过"),
("黄蓉", "郭靖"),
("洪七公", "欧阳锋")

Spark代码

package test

import org.apache.spark.sql.SparkSession
import org.apache.spark.sql.functions._
import scala.util.hashing.MurmurHash3

object randomV2 {
  def main(args: Array[String]): Unit = {
    val spark = SparkSession.builder()
      .appName("ColorGeneration")
      .master("local[*]")
      .getOrCreate()

    import spark.implicits._

    // 创建DataFrame使用提供的数据,这里是测试数据,
    //生产环境中我们一般是读取的上一个节点传来的dataframe,直接调下面的方法,自定义函数即可,
    //完全可以实现我们想要的功能,可根据我们的具体虚修再做修改
    //val df = spark.read.csv("xxx.csv", header = true, inferSchema = true),
    //20231117lxh
    //https://blog.csdn.net/qq_52128187?type=blog

    val data = Seq(
     ("吃饭", "123"),
    ("吃饭", "宋江"),
    ("郭靖", "宋江"),
    ("杨过", "奥特曼"),
    ("周芷若", "张无忌"),
    ("石破天", "谢逊"),
    ("赵敏", "张三丰"),
    ("小龙女", "杨过"),
    ("黄蓉", "郭靖"),
    ("洪七公", "欧阳锋")
    )
    val df1 = data.toDF("a1", "a2")
    

    // 定义基于种子的随机颜色生成函数
    def getRandomColorFromSeed(seed: String): String = {
      val hashed = MurmurHash3.stringHash(seed) // 使用MurmurHash3生成种子的哈希值
      //https://blog.csdn.net/qq_52128187?type=blog
      val r = (hashed & 0xFF0000) >> 16
      val g = (hashed & 0x00FF00) >> 8
      val b = hashed & 0x0000FF
      f"#$r%02x$g%02x$b%02x"
    }

    val getRandomColorWithSeedUDF = udf((seed: String) => getRandomColorFromSeed(seed))

    val dfWithColor = df1.withColumn("c1", getRandomColorWithSeedUDF($"a1"))

    dfWithColor.show() // 显示包含使用相同随机种子生成的新 "c1" 列的 DataFrame //20231117lxh
  }
}

输出结果:

+----+-------+------+
|  a1|     a2|    c1|
+----+-------+------+
|吃饭|    123|#ff5e52|
|吃饭|   宋江|#cfac7d|
|郭靖|   宋江|#e0e0e0|
|杨过|奥特曼|#ff5e52|
|周芷若|张无忌|#ffb961|
|石破天|   谢逊|#1c6a77|
|赵敏|张三丰|#ff89a7|
|小龙女|   杨过|#ff5e52|
|黄蓉|   郭靖|#e0e0e0|
|洪七公|  欧阳锋|#1298d5|
+----+-------+------+

这是其中一版,能基本实现我生产中的需求,还有第二版回头再补充吧


http://www.kler.cn/a/135896.html

相关文章:

  • 基于标签相关性的多标签学习
  • 半导体企业如何利用 Jira 应对复杂商业变局?
  • 1小时构建Vue3知识体系之vue的生命周期函数
  • vue2或vue3的name属性有什么作用?
  • 解决:WSL2可视化opencv和pyqt冲突:QObject::moveToThread
  • 深入剖析【C++继承】:单一继承与多重继承的策略与实践,解锁代码复用和多态的编程精髓,迈向高级C++编程之旅
  • 今天遇到Windows 10里安装的Ubuntu(WSL)的缺点
  • 搜索引擎ElasticSearch分布式搜索和分析引擎学习,SpringBoot整合ES个人心得
  • 【Linux 源码阅读记录】设备树解析 of 相关代码
  • idea显示pom.xml文件漂黄警告 Dependency maven:xxx:xxx is vulnerable
  • Jenkins自动化部署(虚拟机部署)
  • openssl + 3DES开发实例(linux)
  • Android Studio常见问题
  • redis 非关系型数据库
  • 每天一道算法题(七)——求一个数组中最多能存储多少雨水(困难)
  • 车牌识别 支持12种中文车牌类型 车牌数据集下载
  • 多参数训练Isolation Forest
  • Python---函数的嵌套(一个函数里面又调用了另外一个函数)
  • Asp.net MVC Api项目搭建
  • GitHub如何删除仓库
  • 支付宝沙箱支付
  • Unity中Shader矩阵的逆矩阵
  • openfeign、nacos获取接口提供方真实IP
  • new/delete 和malloc/free的区别
  • uni-app 使用vscode开发uni-app
  • 接口自动化和UI自动化的区别