java 實現(xiàn)切割文件和合并文件的功能
java 實現(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)的信息到配置文件
實現(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 文件切割和合并的實例詳解,大家如果有疑問可以留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SpringBoot+RabbitMQ?實現(xiàn)死信隊列的示例
本文主要介紹了SpringBoot+RabbitMQ?實現(xiàn)死信隊列的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06使用springboot logback動態(tài)獲取application的配置項
這篇文章主要介紹了使用springboot logback動態(tài)獲取application的配置項,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08SpringBoot使用JWT實現(xiàn)登錄驗證的方法示例
這篇文章主要介紹了SpringBoot使用JWT實現(xiàn)登錄驗證的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06springboot使用GuavaCache做簡單緩存處理的方法
這篇文章主要介紹了springboot使用GuavaCache做簡單緩存處理的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01基于java時區(qū)轉(zhuǎn)換夏令時的問題及解決方法
下面小編就為大家分享一篇基于java時區(qū)轉(zhuǎn)換夏令時的問題及解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11