Java如何將大文件切割成小文件
運用Java編寫代碼將一個大文件切割成指定大小的小文件
思路:
對已知文件進行切割操作 –> 得到多個碎片文件
使用:
1、 1個字節(jié)輸入流 –> 讀取已知文件中的數(shù)據(jù)
2、 多個字節(jié)輸出流 –> 生成多個碎片文件
思路補充:
創(chuàng)建一個指定大小的byte數(shù)組,將大文件讀取到byte數(shù)組中,讀滿一次將byte數(shù)組寫入一個新的小文件中,如此循環(huán)直到將大文件讀取完畢
注意:此時最后一個小文件可能不足規(guī)定的內(nèi)存大小,在從大文件讀取最后一個byte數(shù)組時,可能還沒讀滿byte數(shù)組,大文件就讀取完畢了,所以只能將最后的未滿足規(guī)定內(nèi)存大小byte數(shù)組寫入最后一個文件中;
具體代碼如下:
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; public class CutDemo { public static void main(String[] args) { //調(diào)用cutFile()函數(shù) 傳人參數(shù)分別為 (原大文件,切割后存放的小文件的路徑,切割規(guī)定的內(nèi)存大?。? cutFile("D:\\java\\cut\\ForrestGump.avi", "D:\\java\\cuts",1024 * 1024 * 20); } private static void cutFile(String src, String endsrc, int num) { FileInputStream fis = null; File file = null; try { fis = new FileInputStream(src); file = new File(src); //創(chuàng)建規(guī)定大小的byte數(shù)組 byte[] b = new byte[num]; int len = 0; //name為以后的小文件命名做準(zhǔn)備 int name = 1; //遍歷將大文件讀入byte數(shù)組中,當(dāng)byte數(shù)組讀滿后寫入對應(yīng)的小文件中 while ((len = fis.read(b)) != -1) { //分別找到原大文件的文件名和文件類型,為下面的小文件命名做準(zhǔn)備 String name2 = file.getName(); int lastIndexOf = name2.lastIndexOf("."); String substring = name2.substring(0, lastIndexOf); String substring2 = name2.substring(lastIndexOf, name2.length()); FileOutputStream fos = new FileOutputStream(endsrc + "\\\\"+ substring + "-" + name + substring2); //將byte數(shù)組寫入對應(yīng)的小文件中 fos.write(b, 0, len); //結(jié)束資源 fos.close(); name++; } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { try { if (fis != null) { //結(jié)束資源 fis.close(); } } catch (IOException e) { e.printStackTrace(); } } } }
對應(yīng)路徑截圖
原大文件路徑截圖:
切割后的小文件執(zhí)行代碼前路徑截圖:
切割后的小文件執(zhí)行代碼后路徑截圖:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Sentinel實現(xiàn)動態(tài)配置的集群流控的方法
這篇文章主要介紹了Sentinel實現(xiàn)動態(tài)配置的集群流控,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04Hadoop 使用IntelliJ IDEA 進行遠程調(diào)試代碼的配置方法
這篇文章主要介紹了Hadoop 使用IntelliJ IDEA 進行遠程調(diào)試代碼的配置方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04SpringBoot中各個層級結(jié)構(gòu)的具體實現(xiàn)
在SpringBoot項目中,常常會把代碼文件放入不同的包中,本文主要介紹了SpringBoot中各個層級結(jié)構(gòu)的具體實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-05-05