在實(shí)際項(xiàng)目中,在處理較大的文件時(shí),常常將文件拆分為多個(gè)子文件進(jìn)行處理,最后再合并這些子文件。今天小編給大家分享的是java合并多個(gè)文件的方法,相信很多人都不太了解,為了讓大家更加了解java合并多個(gè)文件的方法,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。一定會(huì)有所收獲的哦。
鄯善網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,鄯善網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為鄯善上1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的鄯善做網(wǎng)站的公司定做!
Java中合并子文件最容易想到的就是利用BufferedStream進(jìn)行讀寫。
具體的實(shí)現(xiàn)方式如下,代碼很詳細(xì),供各位參考學(xué)習(xí)。
1、首先創(chuàng)建mergeFiles方法,接收字符串?dāng)?shù)組和字符串參數(shù),并完成文件合并功能
public static boolean mergeFiles(String[] fpaths, String resultPath) { if (fpaths == null || fpaths.length < 1 || TextUtils.isEmpty(resultPath)) { return false; } if (fpaths.length == 1) { return new File(fpaths[0]).renameTo(new File(resultPath)); } File[] files = new File[fpaths.length]; for (int i = 0; i < fpaths.length; i ++) { files[i] = new File(fpaths[i]); if (TextUtils.isEmpty(fpaths[i]) || !files[i].exists() || !files[i].isFile()) { return false; } } File resultFile = new File(resultPath); try { int bufSize = 1024; BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(resultFile)); byte[] buffer = new byte[bufSize]; for (int i = 0; i < fpaths.length; i ++) { BufferedInputStream inputStream = new BufferedInputStream(new FileInputStream(files[i])); int readcount; while ((readcount = inputStream.read(buffer)) > 0) { outputStream.write(buffer, 0, readcount); } inputStream.close(); } outputStream.close(); } catch (FileNotFoundException e) { e.printStackTrace(); return false; } catch (IOException e) { e.printStackTrace(); return false; } for (int i = 0; i < fpaths.length; i ++) { files[i].delete(); } return true; }
2、然后在main函數(shù)中對(duì)mergeFiles方法進(jìn)行調(diào)用,使用時(shí)傳入多個(gè)文件的地址數(shù)組,并傳入輸出文件地址即可。
public static void main(String[] args) { mergeFiles(new String[]{"D:/in_1.txt", "D:/in_2.txt", "D:/in_3.txt"}, "D:/output.txt"); }
以上就是java合并多個(gè)文件的方法的詳細(xì)內(nèi)容了,看完之后是否有所收獲呢?如果想了解更多相關(guān)內(nèi)容,歡迎來創(chuàng)新互聯(lián)行業(yè)資訊!