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