Я требовал, чтобы файл json хранился в hdfs, используя API остальных в spark scala - PullRequest
0 голосов
/ 15 апреля 2019

У меня есть API, как показано ниже:

https://api.themoviedb.org/3/search/movie?api_key=29216073ebe788cab8978c4fcbbbad23&query=Kesari

Я хочу сохранить этот результат в виде файла JSON.

implicit val formats = org.json4s.DefaultFormats
import org.apache.spark.sql.SparkSession
import org.json4s.jackson.JsonMethods.parse
import scala.io.Source.fromURL

case class Markets(
        vote_count: String,
        id: String,
        video:String,
        vote_average:String,
        title:String,
        popularity:String,
        poster_path:String,
        original_language:String,
        original_title:String,
        genre_ids:String,
        backdrop_path:String,
        adult:String,
        overview:String,
        release_date:String
            )

case class Result(success: Boolean,
              message: String,
              result: List[Markets])

val parsedData = parse(fromURL("https://api.themoviedb.org/3/search/movie?api_key=29216073ebe788cab8978c4fcbbbad23&query=Kesari").mkString).extract[Array[Result]]

1 Ответ

0 голосов
/ 16 апреля 2019

Добавьте зависимости к вашему проекту:

libraryDependencies ++= Seq(
  "com.github.plokhotnyuk.jsoniter-scala" %% "jsoniter-scala-core" % "0.45.2" % Compile,
  "com.github.plokhotnyuk.jsoniter-scala" %% "jsoniter-scala-macros" % "0.45.2" % Provided // required only in compile-time
)

Затем определите модель, запросите фильмы, проанализируйте ответ и сохраните его в файле:

import java.nio.file._
import java.time.LocalDate

import com.github.plokhotnyuk.jsoniter_scala.macros._
import com.github.plokhotnyuk.jsoniter_scala.core._

import scala.io.BufferedSource
import scala.io.Source.fromURL

case class Movie(
  vote_count: Double,
  id: Double,
  video: Boolean,
  vote_average: Double,
  title: String,
  popularity: Double,
  poster_path: String,
  original_language: String,
  original_title: String,
  genre_ids: List[Double],
  backdrop_path: Option[String],
  adult: Boolean,
  overview: String,
  release_date: LocalDate)

case class Response(
  page: Double,
  total_results: Double,
  total_pages: Double,
  results: List[Movie])

implicit val codec: JsonValueCodec[Response] = JsonCodecMaker.make(CodecMakerConfig())

val parsedData = {
  val source: BufferedSource = fromURL("https://api.themoviedb.org/3/search/movie?api_key=29216073ebe788cab8978c4fcbbbad23&query=Kesari")
  try readFromString(source.mkString)
  finally source.close()
}

Files.write(Paths.get("/tmp/movies.json"), writeToArray(parsedData))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...