Java如何將大文件切割成小文件
運用Java編寫代碼將一個大文件切割成指定大小的小文件
思路:
對已知文件進(jìn)行切割操作 –> 得到多個碎片文件
使用:
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)配置的集群流控,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
Hadoop 使用IntelliJ IDEA 進(jìn)行遠(yuǎn)程調(diào)試代碼的配置方法
這篇文章主要介紹了Hadoop 使用IntelliJ IDEA 進(jìn)行遠(yuǎn)程調(diào)試代碼的配置方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
SpringBoot中各個層級結(jié)構(gòu)的具體實現(xiàn)
在SpringBoot項目中,常常會把代碼文件放入不同的包中,本文主要介紹了SpringBoot中各個層級結(jié)構(gòu)的具體實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-05-05

