Scala:for循环:迭代目录流

时间:2015-03-24 02:12:05

标签: java scala nio

更新 在Scala专家的输入后,我写了以下更新的代码。 以下是更新的代码。 代码编译,但在“run”抛出IllegalStateException:我在代码列表后发布了错误stacktrace:

import java.io.IOException
import java.nio.file.FileSystems
import java.nio.file.FileVisitOption
import java.nio.file.FileVisitResult
import java.nio.file.FileVisitor
import java.nio.file.Files
import java.nio.file.Path
import java.nio.file.Paths
import java.nio.file.attribute.BasicFileAttributes
import java.util.EnumSet
import java.nio.file.{DirectoryStream,DirectoryIteratorException}
 import scala.collection.JavaConversions._

class TestFVis(val searchPath: Path) extends FileVisitor[Path] {

    //Here I provide implementations for postVisitDirectory,  
    //preVisitDirectory, visitFile, and visitFileFailed

}



object Main {

  def main(args: Array[String]) {
    val searchFileOrFolder: Path = Paths.get("C://my_dir")
    println("The Path object is: " + searchFileOrFolder)
    var testFileVisitorTop = new TestFVis(searchFileOrFolder)
    println("Our top level FileVisitor is: " + testFileVisitorTop)

     val opts = EnumSet.of(FileVisitOption.FOLLOW_LINKS)
    val rootDirsIterable: Iterable[Path] = FileSystems.getDefault.getRootDirectories //returns the default filesystem
    // and then returns an Iterable[Path]  to iterate over the paths of the root directories

      var dirStream:Option[DirectoryStream[Path]] = None

      for(rootDir <- rootDirsIterable) {
        println("in the Outer For")
        dirStream= Some(Files.newDirectoryStream(searchFileOrFolder))
        def dstream = dirStream.get
        val streamIter = dstream.iterator().filter((path) => {
                     Files.isRegularFile(path)
                   })

        for( dirStreamUnwrapped <- dirStream;(filePath:Path) <- dirStreamUnwrapped) {
        //for( (filePath: DirectoryStream[Path]) <- dirStream) {
            val tempPath = Files.walkFileTree(filePath, testFileVisitorTop) 
            //val tempPath = Files.walkFileTree(fileOrDir,opts,Integer.MAX_VALUE,testFileVisitorTop)
            println("current path is: " + tempPath)
            if (!testFileVisitorTop.found) {
              println("The file or folder " + searchFileOrFolder+ " was not found!")
            }
        }


      }

  }
}

但是对于历史上下文,这里是我最初得到的编译错误:

[error]  found   : java.nio.file.Path => Unit
[error]  required: java.nio.file.DirectoryStream[java.nio.file.Path] => ?
[error]                 for((filePath:Path) <- dirStream) {

- 更改代码后 代码编译时没有错误,但我在sbt'run'上得到IllegalStateException:\

> run
ur top level FileVisitor is C:\my_dir
Our top level FileVisitor is: com.me.ds.TestFileVisitor
@5564baf6
in the Outer For
[error] (run-main-0) java.lang.IllegalStateException: Iterator already obtained
java.lang.IllegalStateException: Iterator already obtained
        at sun.nio.fs.WindowsDirectoryStream.iterator(WindowsDirectoryStream.jav
a:117)
        at scala.collection.convert.Wrappers$JIterableWrapper.iterator(Wrappers.
scala:54)
        at scala.collection.IterableLike$class.foreach(IterableLike.scala:72)
        at scala.collection.AbstractIterable.foreach(Iterable.scala:54)
        at scala.collection.TraversableLike$WithFilter.foreach(TraversableLike.s
cala:777)
        at com.me.ds.Main$$anonfun$main$1$$anonfun$appl
y$1.apply(SampleFileVis.scala:76)
        at com.me.ds.Main$$anonfun$main$1$$anonfun$appl
y$1.apply(AFileVisitor.scala:76)
        at scala.Option.foreach(Option.scala:256)
        at **com.me.ds.Main$$anonfun$main$1.apply(SampleFileVisitor.scala:76)**
        at com.me.ds.Main$$anonfun$main$1.apply(AFileVi
sitor.scala:68)
        at scala.collection.Iterator$class.foreach(Iterator.scala:743)
        at scala.collection.AbstractIterator.foreach(Iterator.scala:1195)
        at scala.collection.IterableLike$class.foreach(IterableLike.scala:72)
        at scala.collection.AbstractIterable.foreach(Iterable.scala:54)
        at com.me.ds.Main$.main(SampleFileVis.scala:68)
        at com.me.ds.Main.main(SampleFileVis.scala)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
sorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:483)
[trace] Stack trace suppressed: run last compile:run for the full output.
java.lang.RuntimeException: Nonzero exit code: 1
        at scala.sys.package$.error(package.scala:27)
[trace] Stack trace suppressed: run last compile:run for the full output.
[error] (compile:run) Nonzero exit code: 1
[error] Total time: 0 s, completed Mar 24, 2015 7:32:38 AM
>

= ------------- 我也出去调查我自己的错误。如果有人可以指出我正确的方向,这将使我的代码编译和运行,我会在这里完成我的目标。

感谢

2 个答案:

答案 0 :(得分:1)

您使用第一个for进行的所有事情都是展开Option,而Path无法转换为for(dirStreamUnwrapped <- dirStream; (filePath:Path) <- dirStreamUnwrapped) { val tempPath = Files.walkFileTree(filePath, testFVis) } 。您只需要取出未包装的对象并在下一部分中使用它:

{{1}}

答案 1 :(得分:1)

  1. object需要小写。

  2. dirStream需要以val开头。

  3. 最后你有}个太多了。

  4. 您有new TestFileVisitor,但您的意思是new TestFVis

  5. dirStream的类型为:Some[DirectoryStream[Path]],表示您需要(filePath: DirectoryStream[Path]) <- dirStream