`

apache commons io

    博客分类:
  • java
阅读更多
    apche的common io包对文件的io操作进行了封装,我们只需要通过他所提供的几个工具类就可以很简单的完成复杂的io操作。包含6个子包
     * org.apache.commons.io  提供对外工具类
* org.apache.commons.io.comparator 针对文件,有不同的java.util.Comparator类的实现
* org.apache.commons.io.filefilter 很多file filter实现类
* org.apache.commons.io.monitor monitor文件event的组件
  有用的输入和输出流的实现
* org.apache.commons.io.input
* org.apache.commons.io.output

    官方网站http://commons.apache.org/io/index.html
    从官方网站可以下载到io jar包,放到classpath目录下就可以进行使用
   
    主要用三个工具类
/*
  * IOUtils
		 * closeQuietly()
		 * 有多个重写的方法,可以无条件的关闭InputStream,OutputStream,Reader,Writer,Socket等
		 * 
		 * copy()
		 * 多个重写的方法
		 * 可以把输入流中的内容放到输出流中
		 * InputStream||Reader--》OutputStream||Writer(可指定字符集)
		 * 
		 * 大于2GB
		 * copyLarge(InputStream input, OutputStream output) 
		 * copyLarge(Reader input, Writer output) 
		 * 
		 * 从一个输入流中按行读取,返回一个List<String>按行读取
		 * readLines(InputStream||Reader) 
		 * 
		 * toByteArray()||toCharArray()||toString()可以将一个输入流,转换成相应的结果
		 * 同样可以将byte[]||char[]||String放到一个输出流中
		 * 调用重写的write(...)方法
		 */
		InputStream in =null;
		try {
			in = new URL("http://www.baidu.com").openStream();
			//将输入流中的内容转成字符串输出
			System.out.println(IOUtils.toString(in));
		} catch (MalformedURLException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}finally{
			IOUtils.closeQuietly(in);
		}   


/*
		 * FileUtils 文件的读写,copy,delete,按条件查找(filter)
		 */
		String googleUrl = "http://www.google.com";
		String basePath = "F:"+File.separator;
		File file = new File(basePath+"test.txt");
		File file2 = new File(basePath+"book"+File.separator+"11.txt");
		
		try {
			//文件复制 src,destination
			FileUtils.copyFile(file, file2);
			//把一个文件复杂到另一个目录下
			FileUtils.copyFileToDirectory(file, new File(basePath+"book"+File.separator),true);
			//把一个java.net.URL类的content写的指定文件中
			FileUtils.copyURLToFile(new URL(googleUrl),
					new File(basePath+"google.html"));
			//把一个InputStream中的内容写到指定的文件中
			FileUtils.copyInputStreamToFile(new URL(googleUrl).openStream(),
					new File(basePath+"google1.html"));
			//复制一个目录下的所有内容到另一目录下
			FileUtils.copyDirectory(new File(basePath+"test"), 
			                               new File(basePath+"mail"));
			//删除一个目录所有内容
			FileUtils.deleteDirectory(new File(basePath+"test"));
			//在指定的目录中查找扩展名为指定参数的文件,第三个参数是否递归查找
			Collection<File> subFiles =  FileUtils.listFiles(new File(basePath+"mail"),
					                                          new String[]{"html"},false);
			System.out.println(subFiles.size());
			//按行读取给点的文件中的内容,可以指定字符集
			List<String> lines = FileUtils.readLines(file,"GBK");
			for(int i=0;i<lines.size();i++){
				System.out.println(lines.get(i));
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
		 //返回一个给定文件每行内容的迭代
		 LineIterator it = FileUtils.lineIterator(file);
		 try {
		   while (it.hasNext()) {
		     String line = it.nextLine();
		     System.out.println(line);
		   }
		 } finally {
		   LineIterator.closeQuietly(it);
		 } 






/*
		 * FilenameUtils 对文件路径进行处理
		 */
		String path = "c:/helo/123/./0/bird/../11.txt";
		//去掉字符串中的 .&&..
		System.out.println(FilenameUtils.normalize(path)); //c:\helo\123\0\11.txt
		//basePath
		System.out.println(FilenameUtils.getPrefix(path)); //c:/
		//获取文件名
		System.out.println(FilenameUtils.getBaseName(path)); //11
		//获取文件类型扩展名
		System.out.println(FilenameUtils.getExtension(path)); //txt
		//获取文件名(含扩展名)
		System.out.println(FilenameUtils.getName(path)); //11.txt
		//获取文件全路径
		System.out.println(FilenameUtils.getFullPath(path)); //c:/helo/123/./0/bird/../


   
2
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics