Class PathUtils
- Since:
- 2.7
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final CopyOption[]EmptyCopyOptionarray.static final DeleteOption[]EmptyDeleteOptionarray.static final FileAttribute<?>[]EmptyFileAttributearray.static final FileVisitOption[]EmptyFileVisitOptionarray.static final LinkOption[]EmptyLinkOptionarray.static final OpenOption[]EmptyOpenOptionarray.static final Path[]EmptyPatharray.static final LinkOption[]Deprecated.
- 
Method SummaryModifier and TypeMethodDescriptionstatic Counters.PathCounterscleanDirectory(Path directory) Cleans a directory by deleting only files, including in subdirectories, but without deleting the directories.static Counters.PathCounterscleanDirectory(Path directory, DeleteOption... deleteOptions) Cleans a directory by deleting only files, including in subdirectories, but without deleting the directories.static booleancontentEquals(FileSystem fileSystem1, FileSystem fileSystem2) Compares the files of two FileSystems to determine if they are equal or not while considering file contents.static longcopy(IOSupplier<InputStream> in, Path target, CopyOption... copyOptions) Copies the InputStream from the supplier withFiles.copy(InputStream, Path, CopyOption...).static Counters.PathCounterscopyDirectory(Path sourceDirectory, Path targetDirectory, CopyOption... copyOptions) Copies a directory to another directory.static PathcopyFile(URL sourceFile, Path targetFile, CopyOption... copyOptions) Copies a URL to a directory.static PathcopyFileToDirectory(URL sourceFile, Path targetDirectory, CopyOption... copyOptions) Copies a URL to a directory.static PathcopyFileToDirectory(Path sourceFile, Path targetDirectory, CopyOption... copyOptions) Copies a file to a directory.static Counters.PathCounterscountDirectory(Path directory) Counts aspects of a directory including subdirectories.static Counters.PathCounterscountDirectoryAsBigInteger(Path directory) Counts aspects of a directory including subdirectories.static PathcreateParentDirectories(Path path, FileAttribute<?>... attrs) Creates the parent directories for the givenpath.static PathcreateParentDirectories(Path path, LinkOption linkOption, FileAttribute<?>... attrs) Creates the parent directories for the givenpath.static Pathcurrent()Gets the current directory.static Counters.PathCountersDeletes a file or directory.static Counters.PathCountersdelete(Path path, LinkOption[] linkOptions, DeleteOption... deleteOptions) Deletes a file or directory.static Counters.PathCountersdelete(Path path, DeleteOption... deleteOptions) Deletes a file or directory.static Counters.PathCountersdeleteDirectory(Path directory) Deletes a directory including subdirectories.static Counters.PathCountersdeleteDirectory(Path directory, LinkOption[] linkOptions, DeleteOption... deleteOptions) Deletes a directory including subdirectories.static Counters.PathCountersdeleteDirectory(Path directory, DeleteOption... deleteOptions) Deletes a directory including subdirectories.static Counters.PathCountersdeleteFile(Path file) Deletes the given file.static Counters.PathCountersdeleteFile(Path file, LinkOption[] linkOptions, DeleteOption... deleteOptions) Deletes the given file.static Counters.PathCountersdeleteFile(Path file, DeleteOption... deleteOptions) Deletes the given file.static voiddeleteOnExit(Path path) Delegates toFile.deleteOnExit().static booleandirectoryAndFileContentEquals(Path path1, Path path2) Compares the files of two Paths to determine if they are equal or not while considering file contents.static booleandirectoryAndFileContentEquals(Path path1, Path path2, LinkOption[] linkOptions, OpenOption[] openOptions, FileVisitOption[] fileVisitOption) Compares the file sets of two Paths to determine if they are equal or not while considering file contents.static booleandirectoryContentEquals(Path path1, Path path2) Compares the file sets of two Paths to determine if they are equal or not without considering file contents.static booleandirectoryContentEquals(Path path1, Path path2, int maxDepth, LinkOption[] linkOptions, FileVisitOption[] fileVisitOptions) Compares the file sets of two Paths to determine if they are equal or not without considering file contents.static booleanfileContentEquals(Path path1, Path path2) Compares the file contents of two Paths to determine if they are equal or not.static booleanfileContentEquals(Path path1, Path path2, LinkOption[] linkOptions, OpenOption[] openOptions) Compares the file contents of two Paths to determine if they are equal or not.static Path[]filter(PathFilter filter, Path... paths) Applies anIOFileFilterto the providedFileobjects.getAclEntryList(Path sourcePath) Reads the access control list from a file attribute view.static AclFileAttributeViewgetAclFileAttributeView(Path path, LinkOption... options) Shorthand forFiles.getFileAttributeView(path, AclFileAttributeView.class).static StringgetBaseName(Path path) Gets the base name (the part up to and not including the last ".") of the last path segment of a file name.static DosFileAttributeViewgetDosFileAttributeView(Path path, LinkOption... options) Shorthand forFiles.getFileAttributeView(path, DosFileAttributeView.class, options).static StringgetExtension(Path path) Gets the extension of a Path.static <R> RgetFileName(Path path, Function<Path, R> function) Gets the Path's file name and apply the given function if the file name is non-null.static StringgetFileNameString(Path path) Gets the Path's file name as a string.static FileTimegetLastModifiedFileTime(File file) Gets the file's last modified time or null if the file does not exist.static FileTimeGets the file's last modified time or null if the file does not exist.static FileTimeGets the file's last modified time or null if the file does not exist.static FileTimegetLastModifiedFileTime(Path path, FileTime defaultIfAbsent, LinkOption... options) Gets the file's last modified time or null if the file does not exist.static FileTimegetLastModifiedFileTime(Path path, LinkOption... options) Gets the file's last modified time or null if the file does not exist.static PosixFileAttributeViewgetPosixFileAttributeView(Path path, LinkOption... options) Shorthand forFiles.getFileAttributeView(path, PosixFileAttributeView.class).static PathGets aPathrepresenting the system temporary directory.static booleanisDirectory(Path path, LinkOption... options) Tests whether the givenPathis a directory or not.static booleanTests whether the given file or directory is empty.static booleanisEmptyDirectory(Path directory) Tests whether the directory is empty.static booleanisEmptyFile(Path file) Tests whether the given file is empty.static booleanisNewer(Path file, long timeMillis, LinkOption... options) Tests if the givenPathis newer than the given time reference.static booleanisNewer(Path file, FileTime fileTime, LinkOption... options) Tests if the givenPathis newer than the given time reference.static booleanstatic booleanisNewer(Path file, ChronoZonedDateTime<?> czdt, LinkOption... options) Tests if the givenPathis newer than the given time reference.static booleanisNewer(Path file, Instant instant, LinkOption... options) Tests if the givenPathis newer than the given time reference.static booleanisOlder(Path file, long timeMillis, LinkOption... options) Tests if the givenPathis older than the given time reference.static booleanisOlder(Path file, FileTime fileTime, LinkOption... options) Tests if the givenPathis older than the given time reference.static booleanstatic booleanisOlder(Path file, Instant instant, LinkOption... options) Tests if the givenPathis older than the given time reference.static booleanisPosix(Path test, LinkOption... options) Tests whether the given path is on a POSIX file system.static booleanisRegularFile(Path path, LinkOption... options) Tests whether the givenPathis a regular file or not.static DirectoryStream<Path> newDirectoryStream(Path dir, PathFilter pathFilter) Creates a new DirectoryStream for Paths rooted at the given directory.static OutputStreamnewOutputStream(Path path, boolean append) Creates a new OutputStream by opening or creating a file, returning an output stream that may be used to write bytes to the file.static LinkOption[]Copy of theLinkOptionarray forLinkOption.NOFOLLOW_LINKS.static <A extends BasicFileAttributes>
 AreadAttributes(Path path, Class<A> type, LinkOption... options) Reads the BasicFileAttributes from the given path.static BasicFileAttributesreadBasicFileAttributes(Path path) Reads the BasicFileAttributes from the given path.static BasicFileAttributesreadBasicFileAttributes(Path path, LinkOption... options) Reads the BasicFileAttributes from the given path.static BasicFileAttributesDeprecated.static DosFileAttributesreadDosFileAttributes(Path path, LinkOption... options) Reads the DosFileAttributes from the given path.static BasicFileAttributesreadOsFileAttributes(Path path, LinkOption... options) Reads the PosixFileAttributes or DosFileAttributes from the given path.static PosixFileAttributesreadPosixFileAttributes(Path path, LinkOption... options) Reads the PosixFileAttributes from the given path.static StringreadString(Path path, Charset charset) Reads the file contents at the given path as a String using the Charset.static voidsetLastModifiedTime(Path sourceFile, Path targetFile) Sets the giventargetFile's last modified time to the value fromsourceFile.static PathsetReadOnly(Path path, boolean readOnly, LinkOption... linkOptions) Sets the given Path to thereadOnlyvalue.static longReturns the size of the given file or directory.static BigIntegersizeOfAsBigInteger(Path path) Returns the size of the given file or directory.static longsizeOfDirectory(Path directory) Counts the size of a directory recursively (sum of the size of all files).static BigIntegersizeOfDirectoryAsBigInteger(Path directory) Counts the size of a directory recursively (sum of the size of all files).static PathImplements behavior similar to the Unix "touch" utility.static <T extends FileVisitor<? super Path>>
 TvisitFileTree(T visitor, String first, String... more) PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor.static <T extends FileVisitor<? super Path>>
 TvisitFileTree(T visitor, URI uri) PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor.static <T extends FileVisitor<? super Path>>
 TvisitFileTree(T visitor, Path directory) PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor.static <T extends FileVisitor<? super Path>>
 TvisitFileTree(T visitor, Path start, Set<FileVisitOption> options, int maxDepth) PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor.static booleanwaitFor(Path file, Duration timeout, LinkOption... options) Waits for the file system to detect a file's presence, with a timeout.walk(Path start, PathFilter pathFilter, int maxDepth, boolean readAttributes, FileVisitOption... options) Returns a stream of filtered paths.static PathwriteString(Path path, CharSequence charSequence, Charset charset, OpenOption... openOptions) Writes the given character sequence to a file at the given path.
- 
Field Details- 
EMPTY_COPY_OPTIONSEmptyCopyOptionarray.- Since:
- 2.8.0
 
- 
EMPTY_DELETE_OPTION_ARRAYEmptyDeleteOptionarray.- Since:
- 2.8.0
 
- 
EMPTY_FILE_ATTRIBUTE_ARRAYEmptyFileAttributearray.- Since:
- 2.13.0
 
- 
EMPTY_FILE_VISIT_OPTION_ARRAYEmptyFileVisitOptionarray.
- 
EMPTY_LINK_OPTION_ARRAYEmptyLinkOptionarray.
- 
NOFOLLOW_LINK_OPTION_ARRAYDeprecated.LinkOptionarray forLinkOption.NOFOLLOW_LINKS.- Since:
- 2.9.0
 
- 
EMPTY_OPEN_OPTION_ARRAYEmptyOpenOptionarray.
- 
EMPTY_PATH_ARRAYEmptyPatharray.- Since:
- 2.9.0
 
 
- 
- 
Method Details- 
cleanDirectoryCleans a directory by deleting only files, including in subdirectories, but without deleting the directories.- Parameters:
- directory- directory to clean.
- Returns:
- The visitation path counters.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
cleanDirectorypublic static Counters.PathCounters cleanDirectory(Path directory, DeleteOption... deleteOptions) throws IOException Cleans a directory by deleting only files, including in subdirectories, but without deleting the directories.- Parameters:
- directory- directory to clean.
- deleteOptions- How to handle deletion.
- Returns:
- The visitation path counters.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
- Since:
- 2.8.0
 
- 
contentEqualspublic static boolean contentEquals(FileSystem fileSystem1, FileSystem fileSystem2) throws IOException Compares the files of two FileSystems to determine if they are equal or not while considering file contents. The comparison includes all files in all subdirectories.For example, to compare two ZIP files: final Path zipPath1 = Paths.get("file1.zip"); final Path zipPath2 = Paths.get("file2.zip"); try (FileSystem fileSystem1 = FileSystems.newFileSystem(zipPath1, null); FileSystem fileSystem2 = FileSystems.newFileSystem(zipPath2, null)) { assertTrue(PathUtils.directoryAndFileContentEquals(dir1, dir2)); }- Parameters:
- fileSystem1- The first FileSystem.
- fileSystem2- The second FileSystem.
- Returns:
- Whether the two FileSystem contain the same files while considering file contents.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
- Since:
- 2.19.0
 
- 
copypublic static long copy(IOSupplier<InputStream> in, Path target, CopyOption... copyOptions) throws IOException Copies the InputStream from the supplier withFiles.copy(InputStream, Path, CopyOption...).- Parameters:
- in- Supplies the InputStream.
- target- See- Files.copy(InputStream, Path, CopyOption...).
- copyOptions- See- Files.copy(InputStream, Path, CopyOption...).
- Returns:
- See Files.copy(InputStream, Path, CopyOption...)
- Throws:
- IOException- See- Files.copy(InputStream, Path, CopyOption...)
- Since:
- 2.12.0
 
- 
copyDirectorypublic static Counters.PathCounters copyDirectory(Path sourceDirectory, Path targetDirectory, CopyOption... copyOptions) throws IOException Copies a directory to another directory.- Parameters:
- sourceDirectory- The source directory.
- targetDirectory- The target directory.
- copyOptions- Specifies how the copying should be done.
- Returns:
- The visitation path counters.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
copyFilepublic static Path copyFile(URL sourceFile, Path targetFile, CopyOption... copyOptions) throws IOException Copies a URL to a directory.- Parameters:
- sourceFile- The source URL.
- targetFile- The target file.
- copyOptions- Specifies how the copying should be done.
- Returns:
- The target file
- Throws:
- IOException- if an I/O error occurs.
- See Also:
 
- 
copyFileToDirectorypublic static Path copyFileToDirectory(Path sourceFile, Path targetDirectory, CopyOption... copyOptions) throws IOException Copies a file to a directory.- Parameters:
- sourceFile- The source file.
- targetDirectory- The target directory.
- copyOptions- Specifies how the copying should be done.
- Returns:
- The target file
- Throws:
- IOException- if an I/O error occurs.
- See Also:
 
- 
copyFileToDirectorypublic static Path copyFileToDirectory(URL sourceFile, Path targetDirectory, CopyOption... copyOptions) throws IOException Copies a URL to a directory.- Parameters:
- sourceFile- The source URL.
- targetDirectory- The target directory.
- copyOptions- Specifies how the copying should be done.
- Returns:
- The target file
- Throws:
- IOException- if an I/O error occurs.
- See Also:
 
- 
countDirectoryCounts aspects of a directory including subdirectories.- Parameters:
- directory- directory to delete.
- Returns:
- The visitor used to count the given directory.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
countDirectoryAsBigIntegerCounts aspects of a directory including subdirectories.- Parameters:
- directory- directory to count.
- Returns:
- The visitor used to count the given directory.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
createParentDirectoriesCreates the parent directories for the givenpath.If the parent directory already exists, then return it. - Parameters:
- path- The path to a file (or directory).
- attrs- An optional list of file attributes to set atomically when creating the directories.
- Returns:
- The Path for the path's parent directory or null if the given path has no parent.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.9.0
 
- 
createParentDirectoriespublic static Path createParentDirectories(Path path, LinkOption linkOption, FileAttribute<?>... attrs) throws IOException Creates the parent directories for the givenpath.If the parent directory already exists, then return it. - Parameters:
- path- The path to a file (or directory).
- linkOption- A- LinkOptionor null.
- attrs- An optional list of file attributes to set atomically when creating the directories.
- Returns:
- The Path for the path's parent directory or null if the given path has no parent.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
currentGets the current directory.- Returns:
- the current directory.
- Since:
- 2.9.0
 
- 
deleteDeletes a file or directory. If the path is a directory, delete it and all subdirectories.The difference between File.delete()and this method are:- A directory to delete does not have to be empty.
- You get exceptions when a file or directory cannot be deleted; File.delete()returns a boolean.
 - Parameters:
- path- file or directory to delete, must not be- null
- Returns:
- The visitor used to delete the given directory.
- Throws:
- NullPointerException- if the directory is- null
- IOException- if an I/O error is thrown by a visitor method or if an I/O error occurs.
 
- 
deletepublic static Counters.PathCounters delete(Path path, DeleteOption... deleteOptions) throws IOException Deletes a file or directory. If the path is a directory, delete it and all subdirectories.The difference between File.delete() and this method are: - A directory to delete does not have to be empty.
- You get exceptions when a file or directory cannot be deleted; File.delete()returns a boolean.
 - Parameters:
- path- file or directory to delete, must not be- null
- deleteOptions- How to handle deletion.
- Returns:
- The visitor used to delete the given directory.
- Throws:
- NullPointerException- if the directory is- null
- IOException- if an I/O error is thrown by a visitor method or if an I/O error occurs.
- Since:
- 2.8.0
 
- 
deletepublic static Counters.PathCounters delete(Path path, LinkOption[] linkOptions, DeleteOption... deleteOptions) throws IOException Deletes a file or directory. If the path is a directory, delete it and all subdirectories.The difference between File.delete() and this method are: - A directory to delete does not have to be empty.
- You get exceptions when a file or directory cannot be deleted; File.delete()returns a boolean.
 - Parameters:
- path- file or directory to delete, must not be- null
- linkOptions- How to handle symbolic links.
- deleteOptions- How to handle deletion.
- Returns:
- The visitor used to delete the given directory.
- Throws:
- NullPointerException- if the directory is- null
- IOException- if an I/O error is thrown by a visitor method or if an I/O error occurs.
- Since:
- 2.9.0
 
- 
deleteDirectoryDeletes a directory including subdirectories.- Parameters:
- directory- directory to delete.
- Returns:
- The visitor used to delete the given directory.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
deleteDirectorypublic static Counters.PathCounters deleteDirectory(Path directory, DeleteOption... deleteOptions) throws IOException Deletes a directory including subdirectories.- Parameters:
- directory- directory to delete.
- deleteOptions- How to handle deletion.
- Returns:
- The visitor used to delete the given directory.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
- Since:
- 2.8.0
 
- 
deleteDirectorypublic static Counters.PathCounters deleteDirectory(Path directory, LinkOption[] linkOptions, DeleteOption... deleteOptions) throws IOException Deletes a directory including subdirectories.- Parameters:
- directory- directory to delete.
- linkOptions- How to handle symbolic links.
- deleteOptions- How to handle deletion.
- Returns:
- The visitor used to delete the given directory.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
- Since:
- 2.9.0
 
- 
deleteFileDeletes the given file.- Parameters:
- file- The file to delete.
- Returns:
- A visitor with path counts set to 1 file, 0 directories, and the size of the deleted file.
- Throws:
- IOException- if an I/O error occurs.
- NoSuchFileException- if the file is a directory
 
- 
deleteFilepublic static Counters.PathCounters deleteFile(Path file, DeleteOption... deleteOptions) throws IOException Deletes the given file.- Parameters:
- file- The file to delete.
- deleteOptions- How to handle deletion.
- Returns:
- A visitor with path counts set to 1 file, 0 directories, and the size of the deleted file.
- Throws:
- IOException- if an I/O error occurs.
- NoSuchFileException- if the file is a directory.
- Since:
- 2.8.0
 
- 
deleteFilepublic static Counters.PathCounters deleteFile(Path file, LinkOption[] linkOptions, DeleteOption... deleteOptions) throws NoSuchFileException, IOException Deletes the given file.- Parameters:
- file- The file to delete.
- linkOptions- How to handle symbolic links.
- deleteOptions- How to handle deletion.
- Returns:
- A visitor with path counts set to 1 file, 0 directories, and the size of the deleted file.
- Throws:
- IOException- if an I/O error occurs.
- NoSuchFileException- if the file is a directory.
- Since:
- 2.9.0
 
- 
deleteOnExitDelegates toFile.deleteOnExit().- Parameters:
- path- the path to delete.
- Since:
- 3.13.0
 
- 
directoryAndFileContentEqualsCompares the files of two Paths to determine if they are equal or not while considering file contents. The comparison includes all files in all subdirectories.- Parameters:
- path1- The first directory.
- path2- The second directory.
- Returns:
- Whether the two directories contain the same files while considering file contents.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
directoryAndFileContentEqualspublic static boolean directoryAndFileContentEquals(Path path1, Path path2, LinkOption[] linkOptions, OpenOption[] openOptions, FileVisitOption[] fileVisitOption) throws IOException Compares the file sets of two Paths to determine if they are equal or not while considering file contents. The comparison includes all files in all subdirectories.- Parameters:
- path1- The first directory.
- path2- The second directory.
- linkOptions- options to follow links.
- openOptions- options to open files.
- fileVisitOption- options to configure traversal.
- Returns:
- Whether the two directories contain the same files while considering file contents.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
directoryContentEqualsCompares the file sets of two Paths to determine if they are equal or not without considering file contents. The comparison includes all files in all subdirectories.- Parameters:
- path1- The first directory.
- path2- The second directory.
- Returns:
- Whether the two directories contain the same files without considering file contents.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
directoryContentEqualspublic static boolean directoryContentEquals(Path path1, Path path2, int maxDepth, LinkOption[] linkOptions, FileVisitOption[] fileVisitOptions) throws IOException Compares the file sets of two Paths to determine if they are equal or not without considering file contents. The comparison includes all files in all subdirectories.- Parameters:
- path1- The first directory.
- path2- The second directory.
- maxDepth- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- linkOptions- options to follow links.
- fileVisitOptions- options to configure the traversal
- Returns:
- Whether the two directories contain the same files without considering file contents.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
fileContentEqualsCompares the file contents of two Paths to determine if they are equal or not.File content is accessed through Files.newInputStream(Path,OpenOption...).- Parameters:
- path1- the first file path.
- path2- the second file path.
- Returns:
- true if the content of the streams are equal or they both don't exist, false otherwise.
- Throws:
- NullPointerException- if either input is null.
- IOException- if an I/O error occurs.
- See Also:
 
- 
fileContentEqualspublic static boolean fileContentEquals(Path path1, Path path2, LinkOption[] linkOptions, OpenOption[] openOptions) throws IOException Compares the file contents of two Paths to determine if they are equal or not.File content is accessed through RandomAccessFileMode.create(Path).- Parameters:
- path1- the first file path.
- path2- the second file path.
- linkOptions- options specifying how files are followed.
- openOptions- ignored.
- Returns:
- true if the content of the streams are equal or they both don't exist, false otherwise.
- Throws:
- NullPointerException- if openOptions is null.
- IOException- if an I/O error occurs.
- See Also:
 
- 
filterApplies an IOFileFilterto the providedFileobjects. The resulting array is a subset of the original file list that matches the provided filter.The Setreturned by this method is not guaranteed to be thread safe.Set<File> allFiles = ... Set<File> javaFiles = FileFilterUtils.filterSet(allFiles, FileFilterUtils.suffixFileFilter(".java"));- Parameters:
- filter- the filter to apply to the set of files.
- paths- the array of files to apply the filter to.
- Returns:
- a subset of filesthat is accepted by the file filter.
- Throws:
- NullPointerException- if the filter is- null
- IllegalArgumentException- if- filescontains a- nullvalue.
- Since:
- 2.9.0
 
- 
getAclEntryListReads the access control list from a file attribute view.- Parameters:
- sourcePath- the path to the file.
- Returns:
- a file attribute view of the given type, or null if the attribute view type is not available.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.8.0
 
- 
getAclFileAttributeViewShorthand forFiles.getFileAttributeView(path, AclFileAttributeView.class).- Parameters:
- path- the path to the file.
- options- how to handle symbolic links.
- Returns:
- a AclFileAttributeView, or nullif the attribute view type is not available.
- Since:
- 2.12.0
 
- 
getBaseNameGets the base name (the part up to and not including the last ".") of the last path segment of a file name.Will return the file name itself if it doesn't contain any periods. All leading directories of the file nameparameter are skipped.- Parameters:
- path- the path of the file to obtain the base name of.
- Returns:
- the base name of file name
- Since:
- 2.16.0
 
- 
getDosFileAttributeViewShorthand forFiles.getFileAttributeView(path, DosFileAttributeView.class, options).- Parameters:
- path- the path to the file.
- options- how to handle symbolic links.
- Returns:
- a DosFileAttributeView, or nullif the attribute view type is not available.
- Since:
- 2.12.0
 
- 
getExtensionGets the extension of a Path.This method returns the textual part of the Path after the last period. foo.txt --> "txt" a/b/c.jpg --> "jpg" a/b.txt/c --> "" a/b/c --> "" The output will be the same irrespective of the machine that the code is running on. - Parameters:
- path- the path to query.
- Returns:
- the extension of the file or an empty string if none exists or nullif the fileName isnull.
- Since:
- 2.16.0
 
- 
getFileNameGets the Path's file name and apply the given function if the file name is non-null.- Type Parameters:
- R- The function's result type.
- Parameters:
- path- the path to query.
- function- function to apply to the file name.
- Returns:
- the Path's file name as a string or null.
- Since:
- 2.16.0
- See Also:
 
- 
getFileNameStringGets the Path's file name as a string.- Parameters:
- path- the path to query.
- Returns:
- the Path's file name as a string or null.
- Since:
- 2.16.0
- See Also:
 
- 
getLastModifiedFileTimeGets the file's last modified time or null if the file does not exist.The method provides a workaround for bug JDK-8177809 where File.lastModified()looses milliseconds and always ends in 000. This bug is in OpenJDK 8 and 9, and fixed in 11.- Parameters:
- file- the file to query.
- Returns:
- the file's last modified time.
- Throws:
- IOException- Thrown if an I/O error occurs.
- Since:
- 2.12.0
 
- 
getLastModifiedFileTimepublic static FileTime getLastModifiedFileTime(Path path, FileTime defaultIfAbsent, LinkOption... options) throws IOException Gets the file's last modified time or null if the file does not exist.- Parameters:
- path- the file to query.
- defaultIfAbsent- Returns this file time of the file does not exist, may be null.
- options- options indicating how symbolic links are handled.
- Returns:
- the file's last modified time.
- Throws:
- IOException- Thrown if an I/O error occurs.
- Since:
- 2.12.0
 
- 
getLastModifiedFileTimeGets the file's last modified time or null if the file does not exist.- Parameters:
- path- the file to query.
- options- options indicating how symbolic links are handled.
- Returns:
- the file's last modified time.
- Throws:
- IOException- Thrown if an I/O error occurs.
- Since:
- 2.12.0
 
- 
getLastModifiedFileTimeGets the file's last modified time or null if the file does not exist.- Parameters:
- uri- the file to query.
- Returns:
- the file's last modified time.
- Throws:
- IOException- Thrown if an I/O error occurs.
- Since:
- 2.12.0
 
- 
getLastModifiedFileTimeGets the file's last modified time or null if the file does not exist.- Parameters:
- url- the file to query.
- Returns:
- the file's last modified time.
- Throws:
- IOException- Thrown if an I/O error occurs.
- URISyntaxException- if the URL is not formatted strictly according to RFC2396 and cannot be converted to a URI.
- Since:
- 2.12.0
 
- 
getPosixFileAttributeViewShorthand forFiles.getFileAttributeView(path, PosixFileAttributeView.class).- Parameters:
- path- the path to the file.
- options- how to handle symbolic links.
- Returns:
- a PosixFileAttributeView, or nullif the attribute view type is not available.
- Since:
- 2.12.0
 
- 
getTempDirectoryGets aPathrepresenting the system temporary directory.- Returns:
- the system temporary directory.
- Since:
- 2.12.0
 
- 
isDirectoryTests whether the givenPathis a directory or not. Implemented as a null-safe delegate toFiles.isDirectory(Path path, LinkOption... options).- Parameters:
- path- the path to the file.
- options- options indicating how to handle symbolic links
- Returns:
- trueif the file is a directory;- falseif the path is null, the file does not exist, is not a directory, or it cannot be determined if the file is a directory or not.
- Throws:
- SecurityException- In the case of the default provider, and a security manager is installed, the- checkReadmethod is invoked to check read access to the directory.
- Since:
- 2.9.0
 
- 
isEmptyTests whether the given file or directory is empty.- Parameters:
- path- the file or directory to query.
- Returns:
- whether the file or directory is empty.
- Throws:
- IOException- if an I/O error occurs.
 
- 
isEmptyDirectoryTests whether the directory is empty.- Parameters:
- directory- the directory to query.
- Returns:
- whether the directory is empty.
- Throws:
- NotDirectoryException- if the file could not otherwise be opened because it is not a directory (optional specific exception).
- IOException- if an I/O error occurs.
- SecurityException- In the case of the default provider, and a security manager is installed, the- checkReadmethod is invoked to check read access to the directory.
 
- 
isEmptyFileTests whether the given file is empty.- Parameters:
- file- the file to query.
- Returns:
- whether the file is empty.
- Throws:
- IOException- if an I/O error occurs.
- SecurityException- In the case of the default provider, and a security manager is installed, its- checkReadmethod denies read access to the file.
 
- 
isNewerpublic static boolean isNewer(Path file, ChronoZonedDateTime<?> czdt, LinkOption... options) throws IOException Tests if the givenPathis newer than the given time reference.- Parameters:
- file- the- Pathto test.
- czdt- the time reference.
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified after the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isNewerpublic static boolean isNewer(Path file, FileTime fileTime, LinkOption... options) throws IOException Tests if the givenPathis newer than the given time reference.- Parameters:
- file- the- Pathto test.
- fileTime- the time reference.
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified after the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isNewerTests if the givenPathis newer than the given time reference.- Parameters:
- file- the- Pathto test.
- instant- the time reference.
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified after the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isNewerTests if the givenPathis newer than the given time reference.- Parameters:
- file- the- Pathto test.
- timeMillis- the time reference measured in milliseconds since the epoch (00:00:00 GMT, January 1, 1970)
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified after the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.9.0
 
- 
isNewer- Parameters:
- file- the- Fileto test.
- reference- the- Fileof which the modification date is used.
- Returns:
- true if the Fileexists and has been modified more recently than the referenceFile.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
isOlderpublic static boolean isOlder(Path file, FileTime fileTime, LinkOption... options) throws IOException Tests if the givenPathis older than the given time reference.- Parameters:
- file- the- Pathto test.
- fileTime- the time reference.
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified before the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isOlderTests if the givenPathis older than the given time reference.- Parameters:
- file- the- Pathto test.
- instant- the time reference.
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified before the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isOlderTests if the givenPathis older than the given time reference.- Parameters:
- file- the- Pathto test.
- timeMillis- the time reference measured in milliseconds since the epoch (00:00:00 GMT, January 1, 1970)
- options- options indicating how to handle symbolic links.
- Returns:
- true if the Pathexists and has been modified before the given time reference.
- Throws:
- IOException- if an I/O error occurs.
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
isOlder- Parameters:
- file- the- Fileto test.
- reference- the- Fileof which the modification date is used.
- Returns:
- true if the Fileexists and has been modified before than the referenceFile.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
isPosixTests whether the given path is on a POSIX file system.- Parameters:
- test- The Path to test.
- options- options indicating how to handle symbolic links.
- Returns:
- true if test is on a POSIX file system.
- Since:
- 2.12.0
 
- 
isRegularFileTests whether the givenPathis a regular file or not. Implemented as a null-safe delegate toFiles.isRegularFile(Path path, LinkOption... options).- Parameters:
- path- the path to the file.
- options- options indicating how to handle symbolic links.
- Returns:
- trueif the file is a regular file;- falseif the path is null, the file does not exist, is not a directory, or it cannot be determined if the file is a regular file or not.
- Throws:
- SecurityException- In the case of the default provider, and a security manager is installed, the- checkReadmethod is invoked to check read access to the directory.
- Since:
- 2.9.0
 
- 
newDirectoryStreampublic static DirectoryStream<Path> newDirectoryStream(Path dir, PathFilter pathFilter) throws IOException Creates a new DirectoryStream for Paths rooted at the given directory.If you don't use the try-with-resources construct, then you must call the stream's BaseStream.close()method after iteration is complete to free any resources held for the open directory.- Parameters:
- dir- the path to the directory to stream.
- pathFilter- the directory stream filter.
- Returns:
- a new instance.
- Throws:
- IOException- if an I/O error occurs.
 
- 
newOutputStreamCreates a new OutputStream by opening or creating a file, returning an output stream that may be used to write bytes to the file.- Parameters:
- path- the Path.
- append- Whether or not to append.
- Returns:
- a new OutputStream.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
- See Also:
 
- 
noFollowLinkOptionArrayCopy of theLinkOptionarray forLinkOption.NOFOLLOW_LINKS.- Returns:
- Copy of the LinkOptionarray forLinkOption.NOFOLLOW_LINKS.
 
- 
readAttributespublic static <A extends BasicFileAttributes> A readAttributes(Path path, Class<A> type, LinkOption... options) Reads the BasicFileAttributes from the given path. Returns null if the attributes can't be read.- Type Parameters:
- A- The- BasicFileAttributestype
- Parameters:
- path- The Path to test.
- type- the- Classof the file attributes required to read.
- options- options indicating how to handle symbolic links.
- Returns:
- the file attributes or null if the attributes can't be read.
- Since:
- 2.12.0
- See Also:
 
- 
readBasicFileAttributesReads the BasicFileAttributes from the given path.- Parameters:
- path- the path to read.
- Returns:
- the path attributes.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.9.0
 
- 
readBasicFileAttributesReads the BasicFileAttributes from the given path. Returns null if the attributes can't be read.- Parameters:
- path- the path to read.
- options- options indicating how to handle symbolic links.
- Returns:
- the path attributes.
- Since:
- 2.12.0
 
- 
readBasicFileAttributesUncheckedDeprecated.Reads the BasicFileAttributes from the given path. Returns null if the attributes can't be read.- Parameters:
- path- the path to read.
- Returns:
- the path attributes.
- Since:
- 2.9.0
 
- 
readDosFileAttributesReads the DosFileAttributes from the given path. Returns null if the attributes can't be read.- Parameters:
- path- the path to read.
- options- options indicating how to handle symbolic links.
- Returns:
- the path attributes.
- Since:
- 2.12.0
 
- 
readOsFileAttributesReads the PosixFileAttributes or DosFileAttributes from the given path. Returns null if the attributes can't be read.- Parameters:
- path- The Path to read.
- options- options indicating how to handle symbolic links.
- Returns:
- the file attributes.
- Since:
- 2.12.0
 
- 
readPosixFileAttributesReads the PosixFileAttributes from the given path. Returns null instead of throwingUnsupportedOperationException.- Parameters:
- path- The Path to read.
- options- options indicating how to handle symbolic links.
- Returns:
- the file attributes.
- Since:
- 2.12.0
 
- 
readStringReads the file contents at the given path as a String using the Charset.- Parameters:
- path- The source path.
- charset- How to convert bytes to a String, null uses the default Charset.
- Returns:
- the file contents as a new String.
- Throws:
- IOException- if an I/O error occurs reading from the stream.
- Since:
- 2.12.0
- See Also:
 
- 
setLastModifiedTimeSets the giventargetFile's last modified time to the value fromsourceFile.- Parameters:
- sourceFile- The source path to query.
- targetFile- The target path to set.
- Throws:
- NullPointerException- if sourceFile is- null.
- NullPointerException- if targetFile is- null.
- IOException- if setting the last-modified time failed.
- Since:
- 2.12.0
 
- 
setReadOnlypublic static Path setReadOnly(Path path, boolean readOnly, LinkOption... linkOptions) throws IOException Sets the given Path to thereadOnlyvalue.This behavior is OS dependent. - Parameters:
- path- The path to set.
- readOnly- true for read-only, false for not read-only.
- linkOptions- options indicating how to handle symbolic links.
- Returns:
- The given path.
- Throws:
- IOException- if an I/O error occurs.
- Since:
- 2.8.0
 
- 
sizeOfReturns the size of the given file or directory. If the providedPathis a regular file, then the file's size is returned. If the argument is a directory, then the size of the directory is calculated recursively.Note that overflow is not detected, and the return value may be negative if overflow occurs. See sizeOfAsBigInteger(Path)for an alternative method that does not overflow.- Parameters:
- path- the regular file or directory to return the size of, must not be- null.
- Returns:
- the length of the file, or recursive size of the directory, in bytes.
- Throws:
- NullPointerException- if the file is- null.
- IllegalArgumentException- if the file does not exist.
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
sizeOfAsBigIntegerReturns the size of the given file or directory. If the providedPathis a regular file, then the file's size is returned. If the argument is a directory, then the size of the directory is calculated recursively.- Parameters:
- path- the regular file or directory to return the size of (must not be- null).
- Returns:
- the length of the file, or recursive size of the directory, provided (in bytes).
- Throws:
- NullPointerException- if the file is- null.
- IllegalArgumentException- if the file does not exist.
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
sizeOfDirectoryCounts the size of a directory recursively (sum of the size of all files).Note that overflow is not detected, and the return value may be negative if overflow occurs. See sizeOfDirectoryAsBigInteger(Path)for an alternative method that does not overflow.- Parameters:
- directory- directory to inspect, must not be- null.
- Returns:
- size of directory in bytes, 0 if directory is security restricted, a negative number when the real total is greater than Long.MAX_VALUE.
- Throws:
- NullPointerException- if the directory is- null.
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
sizeOfDirectoryAsBigIntegerCounts the size of a directory recursively (sum of the size of all files).- Parameters:
- directory- directory to inspect, must not be- null.
- Returns:
- size of directory in bytes, 0 if directory is security restricted.
- Throws:
- NullPointerException- if the directory is- null.
- IOException- if an I/O error occurs.
- Since:
- 2.12.0
 
- 
touchImplements behavior similar to the Unix "touch" utility. Creates a new file with size 0, or, if the file exists, just updates the file's modified time. this method creates parent directories if they do not exist.- Parameters:
- file- the file to touch.
- Returns:
- The given file.
- Throws:
- NullPointerException- if the parameter is- null.
- IOException- if setting the last-modified time failed or an I/O problem occurs.\
- Since:
- 2.12.0
 
- 
visitFileTreepublic static <T extends FileVisitor<? super Path>> T visitFileTree(T visitor, Path directory) throws IOException PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor. Note thatFiles.walkFileTree(Path,FileVisitor)returns the given path.- Type Parameters:
- T- See- Files.walkFileTree(Path,FileVisitor).
- Parameters:
- visitor- See- Files.walkFileTree(Path,FileVisitor).
- directory- See- Files.walkFileTree(Path,FileVisitor).
- Returns:
- the given visitor.
- Throws:
- NoSuchFileException- if the directory does not exist.
- IOException- if an I/O error is thrown by a visitor method.
- NullPointerException- if the directory is- null.
 
- 
visitFileTreepublic static <T extends FileVisitor<? super Path>> T visitFileTree(T visitor, Path start, Set<FileVisitOption> options, int maxDepth) throws IOException PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor. Note thatFiles.walkFileTree(Path,FileVisitor)returns the given path.- Type Parameters:
- T- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- Parameters:
- visitor- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- start- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- options- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- maxDepth- See- Files.walkFileTree(Path,Set,int,FileVisitor).
- Returns:
- the given visitor.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
visitFileTreepublic static <T extends FileVisitor<? super Path>> T visitFileTree(T visitor, String first, String... more) throws IOException PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor. Note thatFiles.walkFileTree(Path,FileVisitor)returns the given path.- Type Parameters:
- T- See- Files.walkFileTree(Path,FileVisitor).
- Parameters:
- visitor- See- Files.walkFileTree(Path,FileVisitor).
- first- See- Paths.get(String,String[]).
- more- See- Paths.get(String,String[]).
- Returns:
- the given visitor.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
visitFileTreepublic static <T extends FileVisitor<? super Path>> T visitFileTree(T visitor, URI uri) throws IOException PerformsFiles.walkFileTree(Path,FileVisitor)and returns the given visitor. Note thatFiles.walkFileTree(Path,FileVisitor)returns the given path.- Type Parameters:
- T- See- Files.walkFileTree(Path,FileVisitor).
- Parameters:
- visitor- See- Files.walkFileTree(Path,FileVisitor).
- uri- See- Paths.get(URI).
- Returns:
- the given visitor.
- Throws:
- IOException- if an I/O error is thrown by a visitor method.
 
- 
waitForWaits for the file system to detect a file's presence, with a timeout.This method repeatedly tests Files.exists(Path,LinkOption...)until it returns true up to the maximum time given.- Parameters:
- file- the file to check, must not be- null.
- timeout- the maximum time to wait.
- options- options indicating how to handle symbolic links.
- Returns:
- true if file exists.
- Throws:
- NullPointerException- if the file is- null.
- Since:
- 2.12.0
 
- 
walkpublic static Stream<Path> walk(Path start, PathFilter pathFilter, int maxDepth, boolean readAttributes, FileVisitOption... options) throws IOException Returns a stream of filtered paths.The returned Streammay wrap one or moreDirectoryStreams. When you require timely disposal of file system resources, use atry-with-resources block to ensure invocation of the stream'sBaseStream.close()method after the stream operations are completed. Calling a closed stream causes aIllegalStateException.- Parameters:
- start- the start path
- pathFilter- the path filter
- maxDepth- the maximum depth of directories to walk.
- readAttributes- whether to call the filters with file attributes (false passes null).
- options- the options to configure the walk.
- Returns:
- a filtered stream of paths.
- Throws:
- IOException- if an I/O error is thrown when accessing the starting file.
- Since:
- 2.9.0
 
- 
writeStringpublic static Path writeString(Path path, CharSequence charSequence, Charset charset, OpenOption... openOptions) throws IOException Writes the given character sequence to a file at the given path.- Parameters:
- path- The target file.
- charSequence- The character sequence text.
- charset- The Charset to encode the text.
- openOptions- options How to open the file.
- Returns:
- The given path.
- Throws:
- IOException- if an I/O error occurs writing to or creating the file.
- NullPointerException- if either- pathor- charSequenceis- null.
- Since:
- 2.12.0
 
 
- 
noFollowLinkOptionArray().