这次是使用Java7提供的新的方法遍历文件夹。
static Path
上面方法需要FileVisitor参数,FileVisitor代表一个文件访问器,walkFileTree()方法会自动遍历start路径下的
所有文件和子目录,遍历文件和子目录都会触发FileVisitor中相应的方法。这四个方法在下面的代码中出现。
FileVisitor中的四个方法会返回一个FileVisitorResult,它代是一个枚举类,代表访问之后的行为。
FileVisitor定义了如下几种行为:
CONTINUE:代表访问之后的继续行为
SKIP_SIBLINGS:代表继续访问,但不访问该文件或目录的兄弟文件或目录
SKIP_SUBTREE:继续访问,但不访问该目录或文件的子目录
TERMINATE:终止访问
import java.io.IOException; import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.file.FileVisitResult; import java.nio.file.FileVisitor; import java.nio.file.Files; import java.nio.file.Paths; import java.nio.file.attribute.BasicFileAttributes; public class Test { public static void main(String[] args) throws Exception { //遍历d盘下的java文件夹的所有文件 Files.walkFileTree(Paths.get("D:","java"), new FileVisitor(){ @Override public FileVisitResult preVisitDirectory(Object dir, BasicFileAttributes attrs) throws IOException { //访问文件夹之前调用 System.out.println(dir); return FileVisitResult.CONTINUE; } @Override public FileVisitResult visitFile(Object file, BasicFileAttributes attrs) throws IOException { // 访问文件调用 System.out.println(file); return FileVisitResult.CONTINUE; } @Override public FileVisitResult visitFileFailed(Object file, IOException exc) throws IOException { // 访问文件失败时调用 return FileVisitResult.CONTINUE; } @Override public FileVisitResult postVisitDirectory(Object dir, IOException exc) throws IOException { // 访问文件夹之后调用 return FileVisitResult.CONTINUE; } }); } } http://www.java3z.com/cwbwebhome/article/article8/83562.html?id=4655 //取得文件夹路径Path path = Paths.get("D:","java");//在文件夹路径后添加文件InputStream in = Files.newInputStream(pathNext);Path pathNext = path .resolve('1.xml'); //读取文件返回InputStream