Dl4j - CSV數(shù)據(jù)轉(zhuǎn)換

準(zhǔn)備數(shù)據(jù)

0,0,24,9.833333333333334,10,9.7,454,0
0,1,4,17.0,1,17.0,432,0
1,0,2,20.0,1,20.0,0,0
1,1,24,10.375,13,9.615384615384615,455,0
1,1,4,10.75,3,11.0,0,0
0,1,3,16.0,2,16.0,246,0
0,1,6,13.0,4,13.0,4767,0

轉(zhuǎn)換

val sparkConf = new SparkConf()
    .set("spark.serializer", "org.apache.spark.serializer.KryoSerializer")
    .set("spark.kryo.registrator", "org.nd4j.Nd4jRegistrator")
    .setMaster("local[*]")
    .setAppName("Dl4jTransform")

  val useSparkLocal = true

  val spark = SparkSession
    .builder
    .config(sparkConf)
    .getOrCreate()

  def main(args: Array[String]): Unit = {
    val sc = spark.sparkContext
    sc.setLogLevel("ERROR")

    val inputDataSchema = new Schema.Builder()
      .addColumnInteger("geneSid")
      .addColumnInteger("platform")
      .addColumnInteger("loginCount")
      .addColumnDouble("loginHour")
      .addColumnInteger("shareCount")
      .addColumnDouble("shareHour")
      .addColumnDouble("regHours")
      .addColumnCategorical("shareIn", "YES", "NO")
      .build()

    val tp = new TransformProcess.Builder(inputDataSchema)
      .removeColumns("shareHour", "loginHour")
      .convertToInteger("regHours") //轉(zhuǎn)成整數(shù)
//      .transform(new BaseDoubleTransform("regHours") { //自定義轉(zhuǎn)換
//        override def map(writable: Writable): Writable = {
//          new IntWritable(writable.toInt)
//        }
//
//        override def map(o: Any): AnyRef = {
//          val d = o.asInstanceOf[Double]
//          new IntWritable(d.toInt)
//        }
//      })
      .categoricalToInteger("shareIn") // 轉(zhuǎn)成數(shù)字 YES:0  NO:1
      .build()

    val lines = spark.sparkContext.textFile("hello.csv")
    val readWritables = lines.map(new StringToWritablesFunction(new CSVRecordReader()).call(_))
    val processed = SparkTransformExecutor.execute(readWritables, tp)
    val toSave = processed.map(new WritablesToStringFunction("\t"))

    import spark.implicits._
    toSave.rdd.toDS().show(false)
  }

輸出結(jié)果

+------------------------+
|value                   |
+------------------------+
|0  0   24  10  454   0  |
|0  1   4   1   432   0  |
|1  0   2   1   0     0  |
|1  1   24  13  455   1  |
|1  1   4   3   0     0  |
|0  1   3   2   246   0  |
|0  1   6   4   4767  0  |
+------------------------+

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碉怔,一起剝皮案震驚了整個(gè)濱河市丢氢,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌刀荒,老刑警劉巖贡羔,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拴疤,死亡現(xiàn)場離奇詭異邦蜜,居然都是意外死亡媳拴,警方通過查閱死者的電腦和手機(jī)黄橘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屈溉,“玉大人塞关,你說我怎么就攤上這事∽咏恚” “怎么了帆赢?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵小压,是天一觀的道長。 經(jīng)常有香客問我椰于,道長怠益,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任瘾婿,我火速辦了婚禮蜻牢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘偏陪。我一直安慰自己抢呆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布笛谦。 她就那樣靜靜地躺著抱虐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饥脑。 梳的紋絲不亂的頭發(fā)上恳邀,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天,我揣著相機(jī)與錄音灶轰,去河邊找鬼谣沸。 笑死,一個(gè)胖子當(dāng)著我的面吹牛框往,可吹牛的內(nèi)容都是我干的鳄抒。 我是一名探鬼主播,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼椰弊,長吁一口氣:“原來是場噩夢啊……” “哼许溅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起秉版,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤贤重,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后清焕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體并蝗,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年秸妥,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了滚停。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,675評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡粥惧,死狀恐怖键畴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤起惕,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布涡贱,位于F島的核電站,受9級特大地震影響惹想,放射性物質(zhì)發(fā)生泄漏问词。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一嘀粱、第九天 我趴在偏房一處隱蔽的房頂上張望激挪。 院中可真熱鬧,春花似錦草穆、人聲如沸灌灾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至些己,卻和暖如春豌鸡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背段标。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工涯冠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人逼庞。 一個(gè)月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓蛇更,卻偏偏與公主長得像,于是被迫代替她去往敵國和親赛糟。 傳聞我的和親對象是個(gè)殘疾皇子派任,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內(nèi)容