Java将文件分割为多个子文件再将子文件合并成原始文件的示例

 更新时间:2017年02月03日 15:53:03   作者:4舍318  
本篇文章主要介绍了Java将文件分割为多个子文件再将子文件合并成原始文件的示例,具有一定的参考价值,有兴趣的可以了解一下。

Java将文件分割为多个子文件再将子文件合并成原始文件的示例,废话不多说,代码如下:

import java.io.File; 
import java.io.InputStream; 
import java.io.FileInputStream; 
import java.io.OutputStream; 
import java.io.FileOutputStream; 
import java.util.Properties; 
import java.util.Iterator; 
import java.util.TreeSet; 
import java.util.Set; 
 
public class Test 
{ 
  public static void main(String[] args) throws Exception 
  { 
    /* 
    *将一个文件分割为多个文件,然后再组合成一个文件 
    * 找到文件,读入一个1M的buffer中,然后写入一个Part文件中,循环此操作直到文件读取完毕 
    */ 
 
    String sourceFilePath = "D:" + File.separator + "Code" + File.separator + "source" + File.separator + "031316_【第13章:Java类集】_属性类:Properties.wmv"; 
    int partFileLength = 1024*1024;//指定分割的子文件大小为1M 
    splitFile(sourceFilePath,partFileLength);//将文件分割 
    combineFile("D:" + File.separator + "Code" + File.separator + "target");//将分割后的文件合并 
  } 
 
  public static void combineFile(String directoryPath) throws Exception 
  { 
    Properties config = new Properties(); 
    InputStream ips = null; 
    ips = new FileInputStream(new File(directoryPath + File.separator + "config.properties")); 
    config.load(ips); 
 
    Set keySet = config.keySet();//需要将keySet转换为int型 
     
     
    //将keySet迭代出来,转换成int类型的set,排序后存储进去 
    Set<Integer> intSet = new TreeSet<Integer>(); 
    Iterator iterString = keySet.iterator(); 
    while(iterString.hasNext()) 
    { 
      String tempKey = (String)iterString.next(); 
      if("name".equals(tempKey)) 
      {} 
      else 
      { 
        int tempInt ; 
        tempInt = Integer.parseInt(tempKey); 
        intSet.add(tempInt); 
      } 
    } 
     
    Set<Integer> sortedKeySet = new TreeSet<Integer>(); 
    sortedKeySet.addAll(intSet); 
 
    OutputStream eachFileOutput = null; 
    eachFileOutput = new FileOutputStream(new File("D:" + File.separator + "Code" + File.separator + config.getProperty("name"))); 
 
    Iterator iter = sortedKeySet.iterator(); 
    while(iter.hasNext()) 
    { 
      String key = new String("" + iter.next()); 
      if(key.equals("name")) 
      {} 
      else 
      { 
        //System.out.println("debug---"); 
        String fileNumber = null; 
        String filePath = null; 
        fileNumber = key; 
        filePath = config.getProperty(fileNumber); 
 
        //循环读取文件 --> 依次写入 
 
        InputStream eachFileInput = null; 
         
        eachFileInput = new FileInputStream(new File(filePath)); 
         
        byte[] buffer = new byte[1024*1024*1];//缓冲区文件大小为1M 
        int len = 0; 
        while((len = eachFileInput.read(buffer,0,1024*1024*1)) != -1) 
        { 
          eachFileOutput.write(buffer,0,len); 
        } 
        eachFileInput.close(); 
      } 
    } 
 
    eachFileOutput.close(); 
  } 
 
  public static void splitFile(String sourceFilePath,int partFileLength) throws Exception  
  { 
    File sourceFile = null; 
    File targetFile = null; 
    InputStream ips = null; 
    OutputStream ops = null; 
    OutputStream configOps = null;//该文件流用于存储文件分割后的相关信息,包括分割后的每个子文件的编号和路径,以及未分割前文件名 
    Properties partInfo = null;//properties用于存储文件分割的信息 
    byte[] buffer = null; 
    int partNumber = 1; 
    sourceFile = new File(sourceFilePath);//待分割文件 
    ips = new FileInputStream(sourceFile);//找到读取源文件并获取输入流 
    configOps = new FileOutputStream(new File("D:" + File.separator + "Code" //配置文件 
      + File.separator + "target" + File.separator + "config.properties")); 
    buffer = new byte[partFileLength];//开辟缓存空间 
    int tempLength = 0; 
    partInfo = new Properties();//key:1开始自动编号 value:文件路径 
 
    while((tempLength = ips.read(buffer,0,partFileLength)) != -1)  
    { 
      String targetFilePath = "D:" + File.separator + "Code"  
        + File.separator + "target" + File.separator + "part_" + (partNumber);//分割后的文件路径+文件名 
      partInfo.setProperty((partNumber++)+"",targetFilePath);//将相关信息存储进properties 
      targetFile = new File(targetFilePath); 
      ops = new FileOutputStream(targetFile);//分割后文件 
      ops.write(buffer,0,tempLength);//将信息写入碎片文件 
 
      ops.close();//关闭碎片文件 
    } 
    partInfo.setProperty("name",sourceFile.getName());//存储源文件名 
    partInfo.store(configOps,"ConfigFile");//将properties存储进实体文件中 
    ips.close();//关闭源文件流 
  } 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Springboot如何通过yml配置文件为静态成员变量赋值

    Springboot如何通过yml配置文件为静态成员变量赋值

    这篇文章主要介绍了Springboot如何通过yml配置文件为静态成员变量赋值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • 详解Spring 注解之@Import 注入的各种花活

    详解Spring 注解之@Import 注入的各种花活

    这篇文章主要介绍了详解Spring 注解之@Import 注入的各种花活,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • Java在读取文件内容的时候,如何判断出空白行的操作

    Java在读取文件内容的时候,如何判断出空白行的操作

    这篇文章主要介绍了Java在读取文件内容的时候,如何判断出空白行的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Java设计模式七大原则之单一职责原则详解

    Java设计模式七大原则之单一职责原则详解

    单一职责原则(Single Responsibility Principle, SRP),有且仅有一个原因引起类的变更。简单来说,就是针对一个java类,它应该只负责一项职责。本文将详细介绍一下Java设计模式七大原则之一的单一职责原则,需要的可以参考一下
    2022-02-02
  • JVM方法调用invokevirtual详解

    JVM方法调用invokevirtual详解

    JVM调用方法有五条指令,分别是invokestatic,invokespecial,invokevirtual,invokeinterface,invokedynamic,这篇文章主要说明invokevirtual方法的调用问题,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2022-03-03
  • Java通过 Socket 实现 TCP服务端

    Java通过 Socket 实现 TCP服务端

    这篇文章主要介绍了Java通过 Socket 实现 TCP服务端的相关资料,需要的朋友可以参考下
    2017-05-05
  • Java程序中的延迟加载功能使用

    Java程序中的延迟加载功能使用

    这篇文章主要介绍了Java程序中的延迟加载功能使用,一定程度上有助于提升性能和降低内存使用率,需要的朋友可以参考下
    2015-07-07
  • JAVA实现较完善的布隆过滤器的示例代码

    JAVA实现较完善的布隆过滤器的示例代码

    这篇文章主要介绍了JAVA实现较完善的布隆过滤器的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • java实现合并单元格的同时并导出excel示例

    java实现合并单元格的同时并导出excel示例

    这篇文章主要给大家介绍了关于java实现合并单元格的同时并导出excel的相关资料,文中先进行了简单的介绍,之后给出了详细的示例代码,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • springboot基于IDEA环境热加载与热部署教程

    springboot基于IDEA环境热加载与热部署教程

    这篇文章主要为大家介绍了springboot在IDEA环境下的热加载与热部署教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03

最新评论