Java實(shí)現(xiàn)文件分割和文件合并實(shí)例
文件切割和文件合并這個(gè)問(wèn)題困擾了我有一段時(shí)間了(超過(guò)一天沒(méi)做粗來(lái))。
找了好多博客,本來(lái)想轉(zhuǎn)載一個(gè)來(lái)的 結(jié)果找不到了。很無(wú)奈。
只好自己貼代碼上了。
當(dāng)然我會(huì)盡力好好寫(xiě)注釋的。
文件切割器:
import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; import java.io.RandomAccessFile; import java.util.Scanner; public class Main { public static void main(String[] args) throws FileNotFoundException, IOException { File sourceFile = new File("ping.mp3"); // System.out.println(sourceFile.exists()); Scanner scanner = new Scanner(System.in); int numberOfPieces = 1; //默認(rèn)文件切割的數(shù)量 System.out.println("Enter:"); //提示輸入 numberOfPieces = scanner.nextInt(); //輸入 scanner.close(); //輸入后就關(guān)閉 裝完逼就跑一個(gè)道理 long fileLength = sourceFile.length() / numberOfPieces; //分一下每一個(gè)小文件的大小 byte[] b = new byte[1024]; //這個(gè)不解釋 如果看不懂 就去看IO流去吧 RandomAccessFile raf1 = new RandomAccessFile(sourceFile, "r"); int len = -1; for(int i = 0; i < numberOfPieces; i++) { String name = sourceFile.getName() + "." + (i+1); File file = new File(name); file.createNewFile(); RandomAccessFile raf2 = new RandomAccessFile(file, "rw"); while((len = raf1.read(b)) != -1) { raf2.write(b, 0, len); //我覺(jué)的這樣寫(xiě)比raf2.write(b);高明一些 if(raf2.length() > fileLength) //如果太大了就不在這個(gè)子文件寫(xiě)了 換下一個(gè) break; } raf2.close(); } raf1.close(); } }
文件合并器:
import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; import java.io.RandomAccessFile; //文件合并 ping.n public class Main { public static void main(String[] args) throws FileNotFoundException, IOException { File[] files = new File[10]; String name = "ping."; File file = new File("ping.mp3"); file.createNewFile(); RandomAccessFile in = new RandomAccessFile(file, "rw"); in.setLength(0); in.seek(0); byte[] bytes = new byte[1024]; int len = -1; for(int i = 0; i < files.length; i++) { files[i] = new File(name + (i + 1)); //System.out.println(files[i].exists()); RandomAccessFile out = new RandomAccessFile(files[i], "rw"); while((len = out.read(bytes)) != -1) { in.write(bytes, 0, len); } out.close(); } in.close(); } }
文件合并器就不寫(xiě)注釋了,因?yàn)檫@是一個(gè)逆過(guò)程。(懶癌附體)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于Spring?Cache實(shí)現(xiàn)Caffeine+Redis二級(jí)緩存
本文主要介紹了基于Spring?Cache實(shí)現(xiàn)Caffeine+Redis二級(jí)緩存,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03java實(shí)現(xiàn)學(xué)生選課系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)學(xué)生選課系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02關(guān)于Spring Cloud 本地屬性覆蓋的問(wèn)題
這篇文章主要介紹了關(guān)于Spring Cloud 本地屬性覆蓋的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列
這篇文章主要介紹了java 數(shù)據(jù)結(jié)構(gòu)之棧與隊(duì)列的相關(guān)資料,這里對(duì)java中的棧和隊(duì)列都做出實(shí)現(xiàn)實(shí)例來(lái)幫助大家理解學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu),需要的朋友可以參考下2017-07-07淺談java中的一維數(shù)組、二維數(shù)組、三維數(shù)組、多維數(shù)組
下面小編就為大家?guī)?lái)一篇淺談java中的一維數(shù)組、二維數(shù)組、三維數(shù)組、多維數(shù)組。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05