`
风-起-了
  • 浏览: 7324 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

压缩或解压程序实现

    博客分类:
  • java
阅读更多

 

    现在压缩软件其实已经有了很多,自己现在写的这个只是一个学习的过程。

 

    在处理压缩文件的时候,其实重点的就是递归的使用,区分压缩的是文件还是文件夹,并如何处理文件夹下的文件和文件夹。下面就直接把程序贴出来

 

 /**  
 *@Description: 压缩解压文件
 */ 
package cn.lulei.file.zip;  

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.Enumeration;
import java.util.zip.ZipEntry;
import java.util.zip.ZipException;
import java.util.zip.ZipFile;
import java.util.zip.ZipOutputStream;

public class Zip {
	
	private static int BUFFERSIZE = 32;//缓冲流大小
	private static FileOutputStream fileOutputStream = null;
	private static ZipOutputStream zipOutputStream = null;
	private static byte[] array = new byte[BUFFERSIZE];
	
	/**
	 * @param outputDir
	 * @param outputFileName
	 * @throws Exception
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:打开流
	 */
	private static void openZipOutputStream(String outputDir, String outputFileName) throws Exception{
		fileOutputStream = new FileOutputStream(outputDir + "\\" + outputFileName);
		zipOutputStream = new ZipOutputStream(new BufferedOutputStream(fileOutputStream));
	}
	
	/**
	 * @throws Exception
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:关闭流
	 */
	private static void closeZipOutputStream() throws Exception{
		zipOutputStream.close();
		fileOutputStream.close();
	}
	
	/**
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:缓存清空
	 */
	private static void clearArrayBuffer(){
		array = null;
		array = new byte[BUFFERSIZE];
	}
	
	/**
	 * @param inputFile
	 * @param zipOutputStream
	 * @param base
	 * @param isPrint
	 * @throws Exception
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:压缩文件
	 */
	private static void inputFileStream(File inputFile, ZipOutputStream zipOutputStream, String base,  boolean isPrint) throws Exception{
		BufferedInputStream bufferedInputStream = null;
		FileInputStream fileInputStream = new FileInputStream(inputFile);  
		bufferedInputStream = new BufferedInputStream(fileInputStream, BUFFERSIZE);  
		base = base.length() == 0 ? "" : base + "/";
		if (isPrint) {
        	System.out.println(inputFile + "...");
        }
		ZipEntry zipEntry = new ZipEntry(base + inputFile.getName());
		zipOutputStream.putNextEntry(zipEntry);

		clearArrayBuffer();
		while((bufferedInputStream.read(array, 0, BUFFERSIZE))!=-1){  
			zipOutputStream.write(array, 0, BUFFERSIZE); 
		}   
		bufferedInputStream.close();
	}
	
	/**
	 * @param inputFile
	 * @param zipOutputStream
	 * @param base
	 * @param isPrint
	 * @throws Exception
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:压缩文件夹
	 */
	private static void inputDirectoryStream(File inputFile, ZipOutputStream zipOutputStream, String base,  boolean isPrint) throws Exception {
		File[] files = inputFile.listFiles();
		for (File file : files) {
			if (file.isFile()) {
				//这里实现递归调用
				inputFileStream(file, zipOutputStream, base, isPrint);
			} else {
				String baseN = (base.length() == 0 ? "" : base + "/") + file.getName();
				inputDirectoryStream(file, zipOutputStream, baseN, isPrint);
			}
		}
	}
	
	/**
	 * @param inputDir
	 * @param outputDir
	 * @param outputFileName
	 * @param isPrint
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description:压缩文件OR文件夹
	 */
	private static void zip(String inputDir, String outputDir, String outputFileName, boolean isPrint) {
		try {
			File inputFile = new File(inputDir);
			if (!inputFile.exists()) {
				System.out.println("Not found file " + inputDir);
				return;
			}
			File outputFile = new File(outputDir);
			if (!outputFile.exists()) {
				outputFile.mkdirs();
			}
			
			openZipOutputStream(outputDir, outputFileName);
			
			if (inputFile.isDirectory()) {
				inputDirectoryStream(inputFile, zipOutputStream, "", isPrint);
			} else {
				inputFileStream(inputFile, zipOutputStream, "", isPrint);
			}
			
			closeZipOutputStream();
		} catch (Exception e) {
			e.printStackTrace();
		}
		
	}
	
	/**
	 * @param inputFileName
	 * @param outputDir
	 * @param isPrint
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description: 解压文件
	 */
	@SuppressWarnings("rawtypes")
	private static void unZip(String inputFileName, String outputDir, boolean isPrint) {
		try {
			File inputFile = new File(inputFileName);
			if (!inputFile.exists()) {
				System.out.println("Not found file " + inputFileName);
				return;
			}
			File outputFile = new File(outputDir);
			if (!outputFile.exists()) {
				outputFile.mkdirs();
			}
			outputDir = outputDir.endsWith("[/|\\]") ? outputDir : outputDir + "/";
			ZipFile zipFile = null;
			try {
				zipFile = new ZipFile(inputFileName); 
			} catch (ZipException e) {
				System.out.println("File " + inputFileName + " isn't zip");
				return;
			}
            Enumeration enu = zipFile.entries();  
            while(enu.hasMoreElements()){  
                ZipEntry zipEntry = (ZipEntry)enu.nextElement();  
                if(zipEntry.isDirectory()){  
                    new File(outputDir+zipEntry.getName()).mkdirs();  
                    continue;  
                }
                BufferedInputStream bufferedInputStream = new BufferedInputStream(zipFile.getInputStream(zipEntry));  
                File file = new File(outputDir+zipEntry.getName()); 
                if (isPrint) {
                	System.out.println(file + "...");
                }
                File parent = file.getParentFile();  
                if(parent != null && !parent.exists()){  
                    parent.mkdirs();  
                }  
                FileOutputStream fileOutputStream = new FileOutputStream(file);  
                BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(fileOutputStream, BUFFERSIZE);  
                clearArrayBuffer(); 
                while((bufferedInputStream.read(array, 0, BUFFERSIZE))!=-1){  
                	bufferedOutputStream.write(array, 0, BUFFERSIZE); 
                }  
                  
                bufferedOutputStream.flush();  
                bufferedOutputStream.close();
                fileOutputStream.close();
                bufferedInputStream.close();  
            } 
            
		} catch (Exception e) {
			e.printStackTrace();
		}
		
	}
	
	/**
	 * @param fileName
	 * @param isZip
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description: 解压OR压缩文件,不显示进度
	 */
	public static void zipOrUnZip(String fileName, boolean isZip) {
		zipOrUnZip(fileName, isZip, false);
	}
	
	/**
	 * @param fileName
	 * @param isZip
	 * @param isPrint
	 * @Date: 2013-8-8  
	 * @Author: lulei  
	 * @Description: 解压OR压缩文件,显示进度
	 */
	public static void zipOrUnZip(String fileName, boolean isZip, boolean isPrint) {
		File inputFile = new File(fileName);
		if (!inputFile.exists()) {
			System.out.println("Not found file " + fileName);
			return;
		}
		String outputDir = inputFile.getParent();
		if (isZip) {
			String outputFileName = inputFile.getName() + ".zip";
			zip(fileName, outputDir, outputFileName, isPrint);
		} else {
			int i = inputFile.getName().indexOf(".");
			if (i >= 0) {
				outputDir += inputFile.getName().substring(0, i);
				unZip(fileName, outputDir, isPrint);
			} else {
				System.out.println("File " + fileName + " isn't zip");
				return;
			}
		}
	}

	public static void main(String[] args) {
		// TODO Auto-generated method stub  
		Zip.zipOrUnZip("f:/outdoc", true, true);
		Zip.zipOrUnZip("f:/outdoc.zip", false, true);
	}
}

 

最后可以直接调用zipOrUnZip()方法来实现压缩和解压功能即可

分享到:
评论

相关推荐

    压缩/解压程序

    在IT领域,压缩和解压程序是至关重要的工具,它们被广泛用于节省存储空间、方便数据传输和管理大型文件集合。本项目提供的源代码旨在实现这样的功能,让我们深入探讨一下这个"压缩/解压程序"涉及到的核心知识点。 ...

    基于哈夫曼编码的文件压缩解压程序的C语言实现

    在C语言中实现基于哈夫曼编码的文件压缩解压程序,需要深入理解哈夫曼编码的基本原理以及C语言编程技巧。 首先,哈夫曼编码是根据字符出现频率进行编码的一种方法。它通过构建一棵特殊的二叉树——哈夫曼树(也称为...

    C语言实现Zip压缩解压.rar

    总之,C语言实现ZIP压缩解压涉及文件操作、数据压缩算法和ZIP文件格式的理解。通过学习和应用相关库,开发者可以创建自己的ZIP工具,满足特定的需求。这个过程既锻炼了C语言编程技能,也加深了对文件压缩技术的理解...

    Linux c++ 实现哈夫曼文件压缩与解压+迷宫

    在本项目中,我们主要探讨的是利用Linux操作系统下的C++编程语言实现哈夫曼编码进行文件的压缩与解压,并且结合生成随机迷宫及寻找最短路径算法。以下是相关知识点的详细说明: 1. **哈夫曼编码**:哈夫曼编码是一...

    asp在线压缩解压程序

    总的来说,ASP在线压缩解压程序为Web用户提供了一种便捷的文件管理工具,使得在没有本地压缩软件的情况下也能实现文件的压缩和解压。然而,由于ASP主要应用于Windows服务器环境,这种解决方案可能不适用于其他操作...

    LZ78算法实现对任意字符串的压缩与解压

    在Java程序中,你需要编写两个主要类:一个用于压缩,另一个用于解压。这两个类都需要维护字典状态,并按照上述步骤进行操作。同时,为了便于使用,可以设计一个主类来接收用户输入,调用压缩和解压类,并输出结果。...

    压缩与解压程序

    在IT领域,压缩和解压程序是...总结,压缩与解压程序是现代数字生活中不可或缺的工具,而WinRAR凭借其强大功能和易用性,成为了用户的首选之一。了解并熟练运用这些工具,可以极大地提高我们的工作效率和数据管理能力。

    C语言实现哈夫曼编码压缩和解压各种文件

    实验内容:写出程序,利用哈弗曼编码实现对文件的压缩,并能解压文件。 实验步骤: 1、压缩 (1) 统计原始文件中各字节出现的概率(次数); (2) 采用哈弗曼算法对各字节进行编码,建立哈弗曼对照表; a) 构造...

    数据结构大作业基于哈夫曼编码的压缩和解压实现 - 副本.doc

    * 程序构成的应用:用于实现文件压缩和解压,用于构成程序的各个部分 知识点七:文件压缩和解压 * 文件压缩是指将文件压缩到较小的大小,以便存储和传输 * 文件解压是指将压缩后的文件恢复到原来的大小 * 文件压缩...

    Zlib压缩解压工具

    Zlib压缩解压工具是一款基于Zlib库的实用程序,用于对数据进行高效压缩和解压缩。Zlib是由Jean-loup Gailly和Mark Adler开发的开源库,它广泛应用于各种软件开发,尤其是在网络传输和文件存储方面。该工具特别适合...

    C语言实现lz78算法压缩和解压序列

    实验内容:写出程序,利用LZ78编码实现对某字符序列的二元压缩(二元压缩,即编成二进制序列),并能解压。 实验步骤: 1、压缩 (1) 为字符序列中可能出现的字符进行二进制编码 (2) 根据LZ78编码算法为字符序列...

    VS2015 C++ 调用7z SDK实现压缩和解压

    7-Zip是一款免费且开源的压缩软件,其SDK提供了丰富的API接口,允许开发者在自己的应用程序中集成压缩和解压功能。 首先,你需要获取7-Zip的SDK。可以从7-Zip的官方网站下载源代码包,其中包括了用于开发的头文件和...

    实现java文件压缩与解压

    ### 实现Java文件压缩与解压 #### 一、引言 在计算机科学领域,文件压缩与解压是一项非常实用的技术。它不仅能够减少文件占用的空间,提高存储效率,还能加速文件在网络中的传输速度。Java作为一种广泛使用的编程...

    C++ Zlib库实现zip文件压缩解压(支持递归压缩)

    本篇文章将详细介绍如何在`C++`中利用`Zlib`库实现对`zip`文件的压缩和解压,并特别关注其支持的递归压缩特性,以及如何将其与自动更新功能结合使用。 首先,我们需要理解`Zlib`库的基本原理。`Zlib`库基于`DEFLATE...

    txt文件压缩解压程序

    总结来说,这个"txt文件压缩解压程序"利用了赫夫曼编码的高效压缩特性,并结合Xcode的开发工具,实现了对txt文件的压缩和解压功能。通过理解赫夫曼编码的工作原理和Xcode的使用,我们可以更好地理解和应用这个程序,...

    根据哈夫曼编码写的数据压缩解压软件(java实现)

    在Java中实现哈夫曼编码的数据压缩和解压软件,需要理解以下几个关键步骤和技术: 1. **构建哈夫曼树**:首先,需要统计输入文本中每个字符的出现频率。然后,基于这些频率构建一个哈夫曼树(也称为最优二叉树)。...

    C#实现winform压缩解压文件夹

    总的来说,使用C#和WinForm创建文件夹的压缩解压工具,虽然涉及到的技术并不深奥,但实现一个完整且用户体验良好的应用仍然需要考虑很多细节,包括错误处理、用户交互以及性能优化。通过不断地实践和学习,你可以...

    ZIP压缩和解压类

    1. 读取ZIP头:解压程序首先读取ZIP文件的头信息,了解文件的结构。 2. 分析ZIP目录:解析ZIP文件中的中央目录,获取所有文件的压缩数据位置和元数据。 3. 解压缩数据:根据目录信息,逐个读取并解压缩数据块,恢复...

    哈夫曼树实现文件压缩和解压(源程序+实验报告)

    用下表给出的字符集和频度的实际统计数据建立哈夫曼树,并实现以下报文的编码和译码:“THIS PROGRAME IS MY FAVORITE”。 字符 A B C D E F G H I J K L M 频度 186 64 13 22 32 103 21 15 47 57 1 5 32 20 字符 N ...

    赫夫曼编码压缩也解压文件

    "Huffman_coding_finish" 文件可能是C语言实现的赫夫曼编码压缩和解压程序的源代码,包括了赫夫曼树的构建、编码生成、压缩和解压缩的算法。 在这个课程设计中,学生不仅可以学习到赫夫曼编码的理论,还能实际动手...

Global site tag (gtag.js) - Google Analytics