有同样的问题,我用一个简单的尝试/成功/失败来处理
val acc:DataFrame = session.createDataset(List("foo", "bar")).toDF()
val tryDf:Try[DataFrame] =
Try(
session.read.parquet("s3://path-to-bucket/path-to-folder-with-no-parquet-files-under-it/")
)
val resultDf:DataFrame = tryDf match {
case Success(df) => acc.union(df)
case Failure(f) => {
println(s"@@ handled ${ f }") // => @@ handled org.apache.spark.sql.AnalysisException: Unable to infer schema for Parquet. It must be specified manually.;
acc
}
}
println(s"resultDf.count ${ resultDf.count }") // => 2```