当前位置: 首页 > 面试题库 >

在Apache Spark中读取多行JSON

孟自强
2023-03-14
问题内容

我试图将JSON文件用作小型数据库。在DataFrame上创建模板表后,我使用SQL查询了该表并得到了异常。这是我的代码:

val df = sqlCtx.read.json("/path/to/user.json")
df.registerTempTable("user_tt")

val info = sqlCtx.sql("SELECT name FROM user_tt")
info.show()

df.printSchema() 结果:

root
 |-- _corrupt_record: string (nullable = true)

我的JSON文件:

{
  "id": 1,
  "name": "Morty",
  "age": 21
}

展品:

Exception in thread "main" org.apache.spark.sql.AnalysisException: cannot resolve 'name' given input columns: [_corrupt_record];

我该如何解决?

UPD

_corrupt_record

+--------------------+
|     _corrupt_record|
+--------------------+
|                   {|
|            "id": 1,|
|    "name": "Morty",|
|           "age": 21|
|                   }|
+--------------------+

UPD2

这很奇怪,但是当我重写JSON以使其成为一体时,一切正常。

{"id": 1, "name": "Morty", "age": 21}

所以问题出在newline

UPD3

我在文档中发现了下一个句子:

请注意,以json文件形式提供的文件不是典型的JSON文件。每行必须包含一个单独的,自包含的有效JSON对象。因此,常规的多行JSON文件通常会失败。

将JSON保持这种格式并不方便。是否有任何解决方法摆脱JSON的多行结构或将其转换为oneliner?


问题答案:

火花 > = 2.2

Spark 2.2引入了可用于加载JSON(非JSONL)文件的选项: wholeFile multiLine

spark.read
  .option("multiLine", true).option("mode", "PERMISSIVE")
  .json("/path/to/user.json")

看到:

  • SPARK-18352 - 解析正常,多行的JSON文件(不只是JSON线)
  • SPARK-20980 - 重命名选项wholeFilemultiLine对JSON和CSV。

火花 <2.2

好吧,使用JSONL格式的数据可能会带来不便,但我将认为这不是API的问题,而是格式本身的问题。JSON并非设计为在分布式系统中并行处理。

它不提供任何模式,并且不对其格式和形状做一些非常具体的假设,几乎不可能正确识别顶级文档。可以说,这是想像在Apache
Spark等系统中使用的最糟糕的格式。在分布式系统中编写有效的JSON也非常棘手,并且通常不切实际。

话虽如此,如果单个文件是有效的JSON文档(单个文档或文档数组),则可以随时尝试wholeTextFiles

spark.read.json(sc.wholeTextFiles("/path/to/user.json").values())


 类似资料:
  • 我试图从外部文本文件中读取dataframe模式,并使用它创建一个dataframe。然而,我无法理解如何将string转换为StructType。 我正在使用Spark 2.1和Java。这是代码片段。 如何将上述代码中的struct2转换为StructType? 结构文件包含这个

  • 问题内容: 我们的教授让我们用Java进行一些基本的编程,他提供了一个网站以及所有可以注册和提交问题的内容,因为今天我需要做一个例子,我觉得自己处在正确的轨道上,但是我无法找出其余的。这是实际的问题: 这是到目前为止我得到的: 现在,我总是会得到答案,因为我正在阅读单行,如何考虑所有行?谢谢 由于某些奇怪的原因,每次我要执行时都会出现此错误: 无论我使用什么版本的答案,都会出现此错误,该怎么办?

  • 问题内容: 我想在运行后从命令行输入我的输入 输入示例可以是: 我的问题是: 1)如何使用我的输入创建列表数据? 2)如何让Python知道我已经完成了输入,它应该执行其余的代码? 问题答案: 该问题的解决方案取决于您使用的操作系统。 基本上,如果您想使用多行输入,则必须使用代替。由于在Python中是类似文件的对象,因此该方法将一直读取到到达文件末尾为止。它以特殊字符(文件结尾)标记。在不同的操

  • 问题内容: 我想创建一个Python程序,该程序需要多行用户输入。例如: 如何接收多行原始输入? 问题答案: 要将每一行作为字符串获取,你可以执行以下操作: Python 3:

  • 我想有一个以上的regex如下所示,我如何将其添加到flatmap迭代器中,以便在单个流读取期间将该行的所有匹配值列表? 这个问题是从匹配模式和使用Java8 stream将流写入文件中的扩展

  • 所以我必须阅读5个文件行,显示如下(Java): 我必须输入以分号分隔的数据作为单个变量,即<代码>国际价格;等 从文件中读取时,如何将、、等分为不同的数据类型?目标是构建一个对象列表,其中每个数据都作为构造函数参数。 谢谢你的任何帮助