Spark如何读取文件并在文件名的开头加下划线?

iam*_*ven 5 scala apache-spark

当我使用Spark来解析日志文件时,我注意到如果filename的第一个字符是_,则结果将为空.这是我的测试代码:

SparkSession spark = SparkSession
  .builder()
  .appName("TestLog")
  .master("local")
  .getOrCreate();
JavaRDD<String> input = spark.read().text("D:\\_event_2.log").javaRDD();
System.out.println("size : " + input.count());
Run Code Online (Sandbox Code Playgroud)

如果我将文件名修改为event_2.log,代码将正确运行它.我发现该text函数定义为:

@scala.annotation.varargs
def text(paths: String*): Dataset[String] = {
  format("text").load(paths : _*).as[String](sparkSession.implicits.newStringEncoder)
}
Run Code Online (Sandbox Code Playgroud)

我认为这可能是因为_斯卡拉placeholder.我该如何避免这个问题?

Kie*_*ong 7

这与Scala无关.Spark使用Hadoop Input API来读取文件,该文件忽略以下划线(_)或点(.)开头的每个文件

我不知道如何在Spark中禁用它.

  • @cricket_007 这将是一个很好的答案!(它可能已经在 [here](/sf/answers/1388240801/)。) (2认同)