java 實(shí)現(xiàn)切割文件和合并文件的功能
java 實(shí)現(xiàn)切割文件和合并文件的功能
一、切割文件代碼如下:
需求:將一個媒體文件切割成多個碎片(每個碎片的大小為1M),并添加配置說明文件
1.創(chuàng)建(指定)一個文件夾,用于保存切割出來的碎片
2.創(chuàng)建源文件對象,并傳入一個輸入流對象
3.創(chuàng)建一個緩沖區(qū)為1M
4.創(chuàng)建一個輸入流對象并將源文件對象傳入,創(chuàng)建一個輸出流對象引用
5.每個緩沖區(qū)獲取到碎片時,使用輸出對應(yīng)流對象寫入到一個新的文件
6.寫相應(yīng)的信息到配置文件
實(shí)現(xiàn)代碼:
public class SplitFileTest {
public static void main(String[] args) throws IOException {
/**
* 需求:將一個媒體文件切割成多個碎片(每個碎片的大小為1M),并添加配置說明文件
* 1.創(chuàng)建(指定)一個文件夾,用于保存切割出來的碎片
* 2.創(chuàng)建源文件對象,并傳入一個輸入流對象
* 3.創(chuàng)建一個緩沖區(qū)為1M
* 4.創(chuàng)建一個輸入流對象并將源文件對象傳入,創(chuàng)建一個輸出流對象引用
* 5.每個緩沖區(qū)獲取到碎片時,使用輸出對應(yīng)流對象寫入到一個新的文件
* 6.寫相應(yīng)的信息到配置文件
*/
File partDir = new File("F:\\partsDir");
File src = new File("F:\\周杰倫 - 簡單愛.mp3");
splitFile(src,partDir);
}
private static void splitFile(File src, File partDir) throws IOException {
if(!partDir.exists()){
partDir.mkdirs();
}
byte[] buf = new byte[1024*1024];
FileInputStream fis = new FileInputStream(src);
FileOutputStream fos = null;
int len = 0;
int count = 1;
while ((len=fis.read(buf)) != -1){
fos = new FileOutputStream(new File(partDir,"簡單愛-part"+(count++)));
fos.write(buf,0,len);
fos.close();
}
String filename = src.getName();
int partCount = count;
fos = new FileOutputStream(new File(partDir,count+".properties"));
//創(chuàng)建一個屬性集。
Properties prop = new Properties();
//將配置信息存儲到屬性集中
prop.setProperty("filename",src.getName());
prop.setProperty("partCount",Integer.toString(partCount));
//將屬性集中的信息持久化
prop.store(fos,"part file info");
fos.close();
fis.close();
}
}
二、合并文件代碼如下:
需求:使用SequenceInputStream類來合并碎片文件
1.創(chuàng)建一個list集合,來保存指定文件夾碎片流集合
2.用集合工具類方法Collections.enumeration()方法將list集合轉(zhuǎn)換為Enumeration
3.新建一個SequenceInputStream流對象,并傳入第2步的Enumeration
4.創(chuàng)建一個輸出流對象,創(chuàng)建緩沖區(qū)循環(huán)寫第3步SequenceInputStream讀取的內(nèi)容
public class MergeFileTest {
public static void main(String[] args) throws IOException {
/**
* 需求:使用SequenceInputStream類來合并碎片文件
* 1.創(chuàng)建一個list集合,來保存指定文件夾碎片流集合
* 2.用集合工具類方法Collections.enumeration()方法將list集合轉(zhuǎn)換為Enumeration
* 3.新建一個SequenceInputStream流對象,并傳入第2步的Enumeration
* 4.創(chuàng)建一個輸出流對象,創(chuàng)建緩沖區(qū)循環(huán)寫第3步SequenceInputStream讀取的內(nèi)容
*/
File partDir = new File("F:\\partsDir");
List<FileInputStream> list = new ArrayList<FileInputStream>();
for (int i=1;i<12;i++){
FileInputStream fis = new FileInputStream(new File(partDir,"簡單愛-part"+i));
list.add(fis);
}
Enumeration<FileInputStream> en = Collections.enumeration(list);
SequenceInputStream sis = new SequenceInputStream(en);
FileOutputStream fos = new FileOutputStream(new File(partDir,"000.mp3"));
byte[] buf = new byte[1024];
int len = 0;
while ((len=sis.read(buf)) != -1){
fos.write(buf,0,len);
}
fos.close();
sis.close();
}
}
以上就是關(guān)于java 文件切割和合并的實(shí)例詳解,大家如果有疑問可以留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SpringBoot+RabbitMQ?實(shí)現(xiàn)死信隊(duì)列的示例
本文主要介紹了SpringBoot+RabbitMQ?實(shí)現(xiàn)死信隊(duì)列的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
使用springboot logback動態(tài)獲取application的配置項(xiàng)
這篇文章主要介紹了使用springboot logback動態(tài)獲取application的配置項(xiàng),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
SpringBoot使用JWT實(shí)現(xiàn)登錄驗(yàn)證的方法示例
這篇文章主要介紹了SpringBoot使用JWT實(shí)現(xiàn)登錄驗(yàn)證的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
springboot使用GuavaCache做簡單緩存處理的方法
這篇文章主要介紹了springboot使用GuavaCache做簡單緩存處理的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
基于java時區(qū)轉(zhuǎn)換夏令時的問題及解決方法
下面小編就為大家分享一篇基于java時區(qū)轉(zhuǎn)換夏令時的問題及解決方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11

