Java压缩解压zip技术_动力节点Java学院整理

Java解压缩zip - 多个文件(包括文件夹),对多个文件和文件夹进行压缩,对复杂的文件目录进行解压。压缩方法使用的是可变参数,可以压缩1到多个文件..可以写数组的方式或者一个个写到参数列表里面...

 ZipFiles(zip,"abc",new File("d:/English"),new File("d:/发放数据.xls")); 

测试文件目录结构:

测试的压缩内容:English文件夹和同级的两个excel文件

 File[] files = new File[]{new File("d:/English"),new File("d:/发放数据.xls"),new File("d:/中文名称.xls")}; 

下面是压缩的代码:

 /**
  * 压缩文件-由于out要在递归调用外,所以封装一个方法用来
  * 调用ZipFiles(ZipOutputStream out,String path,File... srcFiles)
  * @param zip
  * @param path
  * @param srcFiles
  * @throws IOException
  *
  */
  public static void ZipFiles(File zip,String path,File... srcFiles) throws IOException{
   ZipOutputStream out = new ZipOutputStream(new FileOutputStream(zip));
   ZipTest.ZipFiles(out,path,srcFiles);
   out.close();
   System.out.println("*****************压缩完毕*******************");
  }
  /**
  * 压缩文件-File
  * @param zipFile zip文件
  * @param srcFiles 被压缩源文件
  *
  */
  public static void ZipFiles(ZipOutputStream out,String path,File... srcFiles){
   path = path.replaceAll("\\*", "/");
   if(!path.endsWith("/")){
    path+="/";
   }
   byte[] buf = new byte[1024];
   try {
    for(int i=0;i<srcFiles.length;i++){
     if(srcFiles[i].isDirectory()){
      File[] files = srcFiles[i].listFiles();
      String srcPath = srcFiles[i].getName();
      srcPath = srcPath.replaceAll("\\*", "/");
      if(!srcPath.endsWith("/")){
       srcPath+="/";
      }
      out.putNextEntry(new ZipEntry(path+srcPath));
     ZipFiles(out,path+srcPath,files);
     }
     else{
      FileInputStream in = new FileInputStream(srcFiles[i]);
      System.out.println(path + srcFiles[i].getName());
      out.putNextEntry(new ZipEntry(path + srcFiles[i].getName()));
      int len;
      while((len=in.read(buf))>0){
       out.write(buf,0,len);
      }
      out.closeEntry();
      in.close();
     }
   }
   } catch (Exception e) {
    e.printStackTrace();
   }
 } 

在压缩的时候,针对文件夹进行判断,然后递归压缩文件。

然后是解压:

/**
  * 解压到指定目录
  * @param zipPath
  * @param descDir
  *
  */
  public static void unZipFiles(String zipPath,String descDir)throws IOException{
   unZipFiles(new File(zipPath), descDir);
  }
  /**
  * 解压文件到指定目录
  * @param zipFile
  * @param descDir
  *
  */
  @SuppressWarnings("rawtypes")
  public static void unZipFiles(File zipFile,String descDir)throws IOException{
   File pathFile = new File(descDir);
   if(!pathFile.exists()){
    pathFile.mkdirs();
   }
  ZipFile zip = new ZipFile(zipFile);
   for(Enumeration entries = zip.getEntries();entries.hasMoreElements();){
    ZipEntry entry = (ZipEntry)entries.nextElement();
    String zipEntryName = entry.getName();
    InputStream in = zip.getInputStream(entry);
    String outPath = (descDir+zipEntryName).replaceAll("\\*", "/");;
    //判断路径是否存在,不存在则创建文件路径
    File file = new File(outPath.substring(0, outPath.lastIndexOf('/')));
    if(!file.exists()){
     file.mkdirs();
    }
    //判断文件全路径是否为文件夹,如果是上面已经上传,不需要解压
    if(new File(outPath).isDirectory()){
     continue;
    }
    //输出文件路径信息
    System.out.println(outPath); 

    OutputStream out = new FileOutputStream(outPath);
    byte[] buf1 = new byte[1024];
    int len;
    while((len=in.read(buf1))>0){
     out.write(buf1,0,len);
    }
    in.close();
    out.close();
    }
   System.out.println("******************解压完毕********************");
  } 

解压的时候,针对文件夹判断创建不存在的文件夹,对文件夹只创建,不进行解压..因为解压是针对文件的,不是文件夹,文件夹需要自己创建。

测试方法:

 public static void main(String[] args) throws IOException {
   /**
   * 压缩文件
   */
   File[] files = new File[]{new File("d:/English"),new File("d:/发放数据.xls"),new File("d:/中文名称.xls")};
   File zip = new File("d:/压缩.zip");
   ZipFiles(zip,"abc",files); 

   /**
   * 解压文件
   */
   File zipFile = new File("d:/压缩.zip");
   String path = "d:/zipfile/";
   unZipFiles(zipFile, path);
  } 

测试方法并没有对异常做任何处理,这是不对的,请不要模仿。

输出结果:

 abc/English/templete.xls
 abc/English/中文/bjpowernode/isea/533/abc/templete.xls
 abc/English/中文/bjpowernode/isea/533/abc/zipfile2/templete.xls
 abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/templete.xls
 abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/zipfile2/templete.xls
 abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/zipfile2/领卡清单.xls
 abc/English/中文/bjpowernode/isea/533/abc/zipfile2/领卡清单.xls
 abc/English/中文/bjpowernode/isea/templete.xls
 abc/English/中文/bjpowernode/isea/领卡清单.xls
 abc/English/中文/bjpowernode/templete.xls
 abc/English/领卡清单.xls
 abc/发放数据.xls
 abc/中文名称.xls
 *****************压缩完毕*******************
 d:/zipfile/abc/中文名称.xls
 d:/zipfile/abc/发放数据.xls
 d:/zipfile/abc/English/领卡清单.xls
 d:/zipfile/abc/English/中文/bjpowernode/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/领卡清单.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/templete.xls
 d:/zipfile/abc/English/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/zipfile2/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/zipfile2/templete.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/zipfile2/zipfile/abc/zipfile2/领卡清单.xls
 d:/zipfile/abc/English/中文/bjpowernode/isea/533/abc/zipfile2/领卡清单.xls
 ******************解压完毕******************** 

以上所述是小编给大家介绍的Java压缩解压zip技术,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • java使用gzip实现文件解压缩示例

    复制代码 代码如下: package com.cjonline.foundation.cpe.action; import java.io.ByteArrayInputStream;import java.io.ByteArrayOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.InputStream;import java.

  • Java 文件解压缩实现代码

    Java实现压缩文件的解压缩操作,缺点是压缩文件内不能含有文件名为中文的的文件,否则会出现如下错误: 复制代码 代码如下: Exception in thread "main" java.lang.IllegalArgumentException: MALFORMED at java.util.zip.ZipCoder.toString(Unknown Source) at java.util.zip.ZipInputStream.readLOC(Unknown Source) at

  • java调用7zip解压压缩包的实例

    前言 最近的项目中需要用到解压缩包的功能,客户给出的压缩包的格式主要是rar和zip,因此就打算使用java调用7zip的命令行进行解压文件,本文主要记录一下实现的过程以及其中遇到的问题. 7zip命令行 7z <command> [<switches>...] <archive_name> [<file_names>...][<@listfiles...>] 7z的commands中包含添加文件到压缩包.从压缩包中删除文件以及提取文件等等多个命

  • java中GZIP压缩解压类使用实例

    java中GZIP压缩解压类使用实例 当我们客户端与服务端进行数据传输时需要走流量,为了节省流量我们常常需要写一个压缩类对数据进行压缩. 实例代码: import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.zip.GZIPInputStream; import java.util.zip.GZIPOutputStr

  • 实例展示使用Java压缩和解压缩7z文件的方法

    压缩为7z文件 首先网络上对7z的压缩内容很少. 尤其是java调用进行压缩的是更少了. 一下是自己完成的一个压缩. 本人进行了测试是成功的. 将压缩的流写如磁盘一个压缩文件中. 然后使用7z的压缩软件进行打开解压. 7-zip的开源项目7-zip-JBinding项目地址(sourceforge) 不多说,调用7z源码进行压缩的方法如下. public byte[] lzmaZip(String xml) throws IOException{ BufferedInputStream inSt

  • java 解压与压缩文件夹的实例详解

     java 解压与压缩文件夹的实例详解 注意:JDK7支持设置编码设置编码格式 zipFile,zipInputStream,zipOutputStream都增加了编码格式,如果是jdk1.6需要其他的包辅助 下面为自带jdk压缩文件夹代码: public void dozip(String srcfile, String zipfile) throws IOException { String temp = ""; File src = new File(srcfile); File

  • Java压缩/解压文件的实现代码

    用java压缩/解压文件: import java.io.*; import java.awt.*; import java.awt.event.*; import java.util.*; import java.util.zip.*; import javax.swing.*; //从压缩包中提取文件 public class ZipExtractDemo extends JFrame{ JFileChooser fileChooser; //文件选择器 JTextField jtfTarg

  • Java解压缩zip - 解压缩多个文件或文件夹实例

    Java解压缩zip - 多个文件(包括文件夹),具体如下: 对多个文件和文件夹进行压缩,对复杂的文件目录进行解压. 压缩方法使用的是可变参数,可以压缩1到多个文件..可以写数组的方式或者一个个写到参数列表里面... ZipFiles(zip,"abc",new File("d:/English"),new File("d:/发放数据.xls")); 测试文件目录结构: 测试的压缩内容:English文件夹和同级的两个excel文件 File[]

  • Java压缩解压zip技术_动力节点Java学院整理

    Java解压缩zip - 多个文件(包括文件夹),对多个文件和文件夹进行压缩,对复杂的文件目录进行解压.压缩方法使用的是可变参数,可以压缩1到多个文件..可以写数组的方式或者一个个写到参数列表里面... ZipFiles(zip,"abc",new File("d:/English"),new File("d:/发放数据.xls")); 测试文件目录结构: 测试的压缩内容:English文件夹和同级的两个excel文件 File[] files

  • Java中的HashSet详解和使用示例_动力节点Java学院整理

    第1部分 HashSet介绍 HashSet 简介 HashSet 是一个没有重复元素的集合. 它是由HashMap实现的,不保证元素的顺序,而且HashSet允许使用 null 元素. HashSet是非同步的.如果多个线程同时访问一个哈希 set,而其中至少一个线程修改了该 set,那么它必须 保持外部同步.这通常是通过对自然封装该 set 的对象执行同步操作来完成的.如果不存在这样的对象,则应该使用 Collections.synchronizedSet 方法来"包装" set.

  • Java 中的HashMap详解和使用示例_动力节点Java学院整理

    第1部分 HashMap介绍 HashMap简介 HashMap 是一个散列表,它存储的内容是键值对(key-value)映射. HashMap 继承于AbstractMap,实现了Map.Cloneable.java.io.Serializable接口. HashMap 的实现不是同步的,这意味着它不是线程安全的.它的key.value都可以为null.此外,HashMap中的映射不是有序的. HashMap 的实例有两个参数影响其性能:"初始容量" 和 "加载因子&quo

  • ArrayList详解和使用示例_动力节点Java学院整理

    第1部分 ArrayList介绍 ArrayList简介 ArrayList 是一个数组队列,相当于 动态数组.与Java中的数组相比,它的容量能动态增长.它继承于AbstractList,实现了List, RandomAccess, Cloneable, java.io.Serializable这些接口. ArrayList 继承了AbstractList,实现了List.它是一个数组队列,提供了相关的添加.删除.修改.遍历等功能. ArrayList 实现了RandmoAccess接口,即提

  • Java JVM原理与调优_动力节点Java学院整理

    JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的.Java虚拟机包括一套字节码指令集.一组寄存器.一个栈.一个垃圾回收堆和一个存储方法域. JVM屏蔽了与具体操作系统平台相关的信息,使Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行.是运行Java应用最底层部分. JDK(Java Development kit) 整个Java的核心,包括了Java运行环境(Java Runtime E

  • Java线程安全的常用类_动力节点Java学院整理

    线程安全类 在集合框架中,有些类是线程安全的,这些都是jdk1.1中的出现的.在jdk1.2之后,就出现许许多多非线程安全的类. 下面是这些线程安全的同步的类: vector:就比arraylist多了个同步化机制(线程安全),因为效率较低,现在已经不太建议使用.在web应用中,特别是前台页面,往往效率(页面响应速度)是优先考虑的. statck:堆栈类,先进后出 hashtable:就比hashmap多了个线程安全 除了这些之外,其他的集合大都是非线程安全的类和接口. 线程安全的类其方法是同步

  • Java中Object toString方法简介_动力节点Java学院整理

    一.Object类介绍  Object类在Java里面是一个比较特殊的类,JAVA只支持单继承,子类只能从一个父类来继承,如果父类又是从另外一个父类继承过来,那他也只能有一个父类,父类再有父类,那也只能有一个,JAVA为了组织这个类组织得比较方便,它提供了一个最根上的类,相当于所有的类都是从这个类继承,这个类就叫Object.所以Object类是所有JAVA类的根基类,是所有JAVA类的老祖宗.所有的类,不管是谁,都是从它继承下来的. 二.toString方法介绍  一个字符串和另外一种类型连接

  • Java IO流体系继承结构图_动力节点Java学院整理

    Java IO体系结构看似庞大复杂,其实有规律可循,要弄清楚其结构,需要明白两点: 1. 其对称性质:InputStream 与 OutputStream, Reader 与 Writer,他们分别是一套字节输入-输出,字符输入-输出体系 2. 原始处理器(适配器)与链接流处理器(装饰器) 其结构图如下: Reader-Writer体系 1. 基类 InputStream与OutputStream是所有字节型输入输出流的基抽象类,同时也是适配器(原始流处理器)需要适配的对象,也是装饰器(链接流处

  • Java日志相关技术_动力节点Java学院整理

    Java日志相关技术 作为一名Java程序员,我们开发了很多Java应用程序,包括桌面应用.WEB应用以及移动应用.然而日志系统是一个成熟Java应用所必不可少的,在开发和调试阶段,日志可以帮助我们更好更快地定位bug:在运行维护阶段,日志系统又可以帮我们记录大部分的异常信息,从而帮助我们更好的完善系统.本文要来分享一些Java程序员最常用的Java日志框架组件. 1.log4j – 最受欢迎的Java日志组件 Log4j是一款基于Java的开源日志组件,Log4j功能非常强大,我们可以将日志信

  • Java中的Web MVC简介_动力节点Java学院整理

    Web开发中的请求-响应模型: 在Web世界里,具体步骤如下: 1.Web浏览器(如IE)发起请求. 2.Web服务器(如Tomcat)接收请求,处理请求(比如用户新增,则将把用户保存一下),最后产生响应(一般为html). 3.web服务器处理完成后,返回内容给web客户端(一般就是我们的浏览器),客户端对接收的内容进行处理(如web浏览器将会对接收到的html内容进行渲染以展示给客户). 因此,在Web世界里: 都是Web客户端发起请求,Web服务器接收.处理并产生响应. 一般Web服务器是

随机推荐