【发布时间】:2021-09-12 14:40:53
【问题描述】:
我正在尝试使用 Pyspark 从 Kafka 主题中读取数据。我想将该数据转换为特定的模式。但做不到。
这是我尝试过的:
>> df = spark.read.format("kafka").option("kafka.bootstrap.servers", "localhost:9092").option("subscribe", "test1").load()
>> userSchema = StructType().add("Name", StringType(), True).add("Age", IntegerType(), True)
>> df1 = df.selectExpr("CAST(value AS STRING)")
>> df2 = df1.select(from_json(col("value"), userSchema))
>> df2.printSchema()
root
|-- jsontostructs(value): struct (nullable = true)
| |-- Name: string (nullable = true)
| |-- Age: integer (nullable = true)
我想要的是:
>> df2.printSchema()
root
|-- Name: string (nullable = true)
|-- Age: integer (nullable = true)
有什么方法可以得到想要的架构?
【问题讨论】:
-
你的输入数据/json长什么样子?
标签: json apache-spark pyspark spark-structured-streaming spark-kafka-integration