FileToolki.java工具类
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.FilenameFilter; import java.io.IOException; import java.io.StringReader; import org.apache.commons.io.FileUtils; import org.apache.commons.io.filefilter.AndFileFilter; import org.apache.commons.io.filefilter.DirectoryFileFilter; import org.apache.commons.io.filefilter.IOFileFilter; import org.apache.commons.io.filefilter.NotFileFilter; import org.apache.commons.io.filefilter.SuffixFileFilter; /** * 文件工具箱 * @author Administrator */ public class FileToolkit { /** * 复制文件或者目录,复制前后文件完全一样。 * * @param resFilePath 源文件路径 * @param distFolder 目标文件夹 * @IOException 当操作发生异常时抛出 */ public static void copyFile(String resFilePath, String distFolder) throws IOException { File resFile = new File(resFilePath); File distFile = new File(distFolder); if(resFile.isDirectory()){ FileUtils.copyDirectoryToDirectory(resFile, distFile); } else if(resFile.isFile()){ FileUtils.copyFileToDirectory(resFile, distFile, true); } } /** * 删除一个文件或者目录 * * @param targetPath 文件或者目录路径 * @IOException 当操作发生异常时抛出 */ public static void deleteFile(String targetPath) throws IOException { File targetFile = new File(targetPath); if (targetFile.isDirectory()) { FileUtils.deleteDirectory(targetFile); } else if (targetFile.isFile()) { targetFile.delete(); } } /** * 移动文件或者目录,移动前后文件完全一样,如果目标文件夹不存在则创建。 * * @param resFilePath 源文件路径 * @param distFolder 目标文件夹 * @IOException 当操作发生异常时抛出 */ public static void removeFile(String resFilePath, String distFolder) throws IOException { File resFile = new File(resFilePath); File distFile = new File(distFolder); if (resFile.isDirectory()) { FileUtils.moveDirectoryToDirectory(resFile, distFile, true); } else if (resFile.isFile()) { FileUtils.moveFileToDirectory(resFile, distFile, true); } } /** * 重命名文件或文件夹 * * @param resFilePath 源文件路径 * @param newFileName 重命名 * @return 操作成功标识 */ public static boolean renameFile(String resFilePath, String newFileName) { String newFilePath = StringToolkit.formatPath(StringToolkit.getParentPath(resFilePath) + "/" + newFileName); File resFile = new File(resFilePath); File newFile = new File(newFilePath); return resFile.renameTo(newFile); } /** * 读取文件或者目录的大小 * * @param distFilePath 目标文件或者文件夹 * @return 文件或者目录的大小,如果获取失败,则返回-1 */ public static long genFileSize(String distFilePath) { File distFile = new File(distFilePath); if (distFile.isFile()) { return distFile.length(); } else if (distFile.isDirectory()) { return FileUtils.sizeOfDirectory(distFile); } return -1L; } /** * 判断一个文件是否存在 * * @param filePath 文件路径 * @return 存在返回true,否则返回false */ public static boolean isExist(String filePath) { return new File(filePath).exists(); } /** * 本地某个目录下的文件列表(不递归) * * @param folder ftp上的某个目录 * @param suffix 文件的后缀名(比如.mov.xml) * @return 文件名称列表 */ public static String[] listFilebySuffix(String folder, String suffix) { IOFileFilter fileFilter1 = new SuffixFileFilter(suffix); IOFileFilter fileFilter2 = new NotFileFilter(DirectoryFileFilter.INSTANCE); FilenameFilter filenameFilter = new AndFileFilter(fileFilter1, fileFilter2); return new File(folder).list(filenameFilter); } /** * 将字符串写入指定文件(当指定的父路径中文件夹不存在时,会最大限度去创建,以保证保存成功!) * * @param res 原字符串 * @param filePath 文件路径 * @return 成功标记 */ public static boolean string2File(String res, String filePath) { boolean flag = true; BufferedReader bufferedReader = null; BufferedWriter bufferedWriter = null; try { File distFile = new File(filePath); if (!distFile.getParentFile().exists()) distFile.getParentFile().mkdirs(); bufferedReader = new BufferedReader(new StringReader(res)); bufferedWriter = new BufferedWriter(new FileWriter(distFile)); char buf[] = new char[1024]; //字符缓冲区 int len; while ((len = bufferedReader.read(buf)) != -1) { bufferedWriter.write(buf, 0, len); } bufferedWriter.flush(); bufferedReader.close(); bufferedWriter.close(); } catch (IOException e) { flag = false; e.printStackTrace(); } return flag; } }
StringToolkit.java工具类
import java.io.File; import java.util.ArrayList; import java.util.List; import java.util.Properties; /** * 字符串工具箱 * @author Administrator */ public final class StringToolkit { /** * 将一个字符串的首字母改为大写或者小写 * * @param srcString 源字符串 * @param flag 大小写标识,ture小写,false大些 * @return 改写后的新字符串 */ public static String toLowerCaseInitial(String srcString, boolean flag) { StringBuilder sb = new StringBuilder(); if (flag) { sb.append(Character.toLowerCase(srcString.charAt(0))); } else { sb.append(Character.toUpperCase(srcString.charAt(0))); } sb.append(srcString.substring(1)); return sb.toString(); } /** * 将一个字符串按照句点(.)分隔,返回最后一段 * * @param clazzName 源字符串 * @return 句点(.)分隔后的最后一段字符串 */ public static String getLastName(String clazzName) { String[] ls = clazzName.split("\\."); return ls[ls.length - 1]; } /** * 格式化文件路径,将其中不规范的分隔转换为标准的分隔符,并且去掉末尾的"/"符号。 * * @param path 文件路径 * @return 格式化后的文件路径 */ public static String formatPath(String path) { String reg0 = "\\\\+"; String reg = "\\\\+|/+"; String temp = path.trim().replaceAll(reg0, "/"); temp = temp.replaceAll(reg, "/"); if (temp.endsWith("/")) { temp = temp.substring(0, temp.length() - 1); } if (System.getProperty("file.separator").equals("\\")) { temp= temp.replace('/','\\'); } return temp; } /** * 格式化文件路径,将其中不规范的分隔转换为标准的分隔符,并且去掉末尾的"/"符号(适用于FTP远程文件路径或者Web资源的相对路径)。 * * @param path 文件路径 * @return 格式化后的文件路径 */ public static String formatPath4Ftp(String path) { String reg0 = "\\\\+"; String reg = "\\\\+|/+"; String temp = path.trim().replaceAll(reg0, "/"); temp = temp.replaceAll(reg, "/"); if (temp.endsWith("/")) { temp = temp.substring(0, temp.length() - 1); } return temp; } public static void main(String[] args) { System.out.println(System.getProperty("file.separator")); Properties p = System.getProperties(); System.out.println(formatPath("C:///\\xxxx\\\\\\\\\\///\\\\R5555555.txt")); // List<String> result = series2List("asdf | sdf|siii|sapp|aaat| ", "\\|"); // System.out.println(result.size()); // for (String s : result) { // System.out.println(s); // } } /** * 获取文件父路径 * * @param path 文件路径 * @return 文件父路径 */ public static String getParentPath(String path) { return new File(path).getParent(); } /** * 获取相对路径 * * @param fullPath 全路径 * @param rootPath 根路径 * @return 相对根路径的相对路径 */ public static String getRelativeRootPath(String fullPath, String rootPath) { String relativeRootPath = null; String _fullPath = formatPath(fullPath); String _rootPath = formatPath(rootPath); if (_fullPath.startsWith(_rootPath)) { relativeRootPath = fullPath.substring(_rootPath.length()); } else { throw new RuntimeException("要处理的两个字符串没有包含关系,处理失败!"); } if (relativeRootPath == null) return null; else return formatPath(relativeRootPath); } /** * 获取当前系统换行符 * * @return 系统换行符 */ public static String getSystemLineSeparator() { return System.getProperty("line.separator"); } /** * 将用“|”分隔的字符串转换为字符串集合列表,剔除分隔后各个字符串前后的空格 * * @param series 将用“|”分隔的字符串 * @return 字符串集合列表 */ public static List<String> series2List(String series) { return series2List(series, "\\|"); } /** * 将用正则表达式regex分隔的字符串转换为字符串集合列表,剔除分隔后各个字符串前后的空格 * * @param series 用正则表达式分隔的字符串 * @param regex 分隔串联串的正则表达式 * @return 字符串集合列表 */ private static List<String> series2List(String series, String regex) { List<String> result = new ArrayList<String>(); if (series != null && regex != null) { for (String s : series.split(regex)) { if (s.trim() != null && !s.trim().equals("")) result.add(s.trim()); } } return result; } /** * @param strList 字符串集合列表 * @return 通过“|”串联为一个字符串 */ public static String list2series(List<String> strList) { StringBuffer series = new StringBuffer(); for (String s : strList) { series.append(s).append("|"); } return series.toString(); } /** * 将字符串的首字母转为小写 * * @param resStr 源字符串 * @return 首字母转为小写后的字符串 */ public static String firstToLowerCase(String resStr) { if (resStr == null) { return null; } else if ("".equals(resStr.trim())) { return ""; } else { StringBuffer sb = new StringBuffer(); Character c = resStr.charAt(0); if (Character.isLetter(c)) { if (Character.isUpperCase(c)) c = Character.toLowerCase(c); sb.append(resStr); sb.setCharAt(0, c); return sb.toString(); } } return resStr; } /** * 将字符串的首字母转为大写 * * @param resStr 源字符串 * @return 首字母转为大写后的字符串 */ public static String firstToUpperCase(String resStr) { if (resStr == null) { return null; } else if ("".equals(resStr.trim())) { return ""; } else { StringBuffer sb = new StringBuffer(); Character c = resStr.charAt(0); if (Character.isLetter(c)) { if (Character.isLowerCase(c)) c = Character.toUpperCase(c); sb.append(resStr); sb.setCharAt(0, c); return sb.toString(); } } return resStr; } }
相关推荐
Apache Commons IO库中的`org.apache.commons.io.FileUtils`类是一个非常实用的工具类,它提供了大量方便、高效的方法,用于处理...使用Apache Commons IO库,特别是`FileUtils`类,可以显著提升Java项目的开发效率。
Apache Commons IO 是一个Java开发库,它提供了许多实用的工具类来处理输入/输出操作。这个包中的类弥补了Java标准库在IO操作上的不足,为开发者提供了更强大的功能和便利性。`org.apache.commons.io`是这个库的核心...
解决Caused by: java.lang.ClassNotFoundException: org.apache.commons.io.FileUtils 类似错误,需要导入jar包,下载地址是http://commons.apache.org/proper/commons-io/download_io.cgi
相较于Java标准库中的`java.io.File`类提供的`copy()`方法,`commons-io`的`FileUtils.copyFile()`更简单易用,且异常处理更简洁。 总的来说,`commons-io-2.5.jar` 是Java开发者的强大工具,它极大地扩展了Java IO...
在`commons.io`库中,主要的包有`org.apache.commons.io`,包含了大部分的核心工具类,如`FileUtils`、`IOUtils`等。 总的来说,`commons.io`是Java开发中不可或缺的一部分,它提供了一系列强大且易于使用的工具,...
在处理文件内容时,`FileUtils.readFileToString()`和`FileUtils.writeStringToFile()`方法使得读取和写入文件变得异常简单,只需要一个方法调用。这些方法还支持指定字符集,对于处理不同编码格式的文件非常有用。 ...
这个压缩包包含了该库的所有编译后的类文件和必要的资源,使得开发者能够在他们的项目中方便地使用Apache Commons IO的功能。 Apache Commons IO库的主要目标是弥补Java标准库中对输入/输出操作支持的不足。在描述...
Apache Commons IO 是一个Java库,...对于JDK 1.6及更高版本的项目,使用"commons-io-2.4"可以确保兼容性和效率。通过理解和运用这些知识点,开发者可以更高效地处理各种输入输出任务,提高代码的可读性和可维护性。
例如,`FileUtils.readFileToString()`可以方便地将一个文件读取为字符串。 2. `IOUtils`:该类包含了一组通用的流处理方法,如复制流、关闭流、读取或写入流中的数据。例如,`IOUtils.copy()`可以用来高效地复制...
例如,`FileUtils.copyFile()` 和 `FileUtils.deleteQuietly()` 方法分别用于文件的复制和安全删除。 2. 流操作:提供了许多对输入/输出流进行读写、转换和操作的工具类,如`BufferedInputStream` 和 `...
本文将深入探讨`commons-io-2.6.jar`中的关键功能和使用方法。 一、文件操作 1. 文件和目录操作:Apache Commons IO提供了一系列API用于创建、删除、复制和移动文件及目录。例如,`FileUtils.copyFile()`和`...
例如,`FileUtils.copyFile()`可以方便地复制文件,而`FileUtils.moveFile()`则用于移动或重命名文件。 2. **流操作**:简化了对输入/输出流的处理,包括读写文件、转换流以及在流之间进行数据传输。比如,`IOUtils...
- `FileUtils.readFileToByteArray()` 和 `FileUtils.writeByteArrayToFile()` 可以方便地将文件读入或写入字节数组,适合处理大文件时的分块操作。 10. **对象序列化与反序列化**: - `ObjectInputStream` 和 `...
【Java基础】-- FileUtils工具类常用方法 ...总之,Apache Commons IO的FileUtils工具类为Java开发者提供了一套强大且易用的文件操作API,极大地简化了日常开发中的文件处理工作,值得在项目中广泛使用。
2. `FileUtils.readFileToString()` 和 `FileUtils.writeStringToFile()`:用于方便地将文件内容转换成字符串,或者将字符串写入文件。 3. `IOUtils `:提供了一些通用的I/O流操作,如复制流、关闭流、读取流到字符...
1. **文件操作**:`org.apache.commons.io.FileUtils` 类提供了大量的静态方法,用于执行文件和目录的各种操作,如复制、移动、删除、创建、读取等。例如,`copyFile()` 和 `copyDirectory()` 方法用于文件和目录的...
FileUtils.moveFile(uploadedFile, new File("newLocation/" + fileName)); ``` 这两个库的结合使用,使得在Java Web应用中处理文件上传和下载变得更加便捷和高效。在实际开发中,还需要考虑安全性问题,如防止文件...
其次,`commons-io-2.1.jar` 是 Apache Commons IO 库的一部分,这是一个广泛使用的 Java IO 工具集。这个库提供了一系列实用的工具类,可以增强 Java 标准库的 IO 功能,包括: 1. **文件操作**:提供 `FileUtils`...
1. **FileUtils**: 提供了大量静态方法来操作文件,如复制、移动、删除、比较文件等,方便且易于使用。 2. **IOUtils**: 包含了许多处理流的工具方法,比如读取流到字符串、关闭流、复制流等,可以减少代码量并提高...
例如,`org.apache.commons.io.FileUtils` 类提供了许多静态方法,用于执行文件操作,如复制、移动、删除文件,或者读取文件内容为字符串等。`org.apache.commons.io.IOUtils` 类则包含了一些处理输入/输出流的方法...