本文實例講述了PHP實現的大文件切割與合并功能。分享給大家供大家參考,具體如下:
分割代碼
split.php
<?php$i = 0; //分割的塊編號$fp = fopen("hadoop.sql","rb"); //要分割的文件$file = fopen("split_hash.txt","a"); //記錄分割的信息的文本文件,實際生產環境存在redis更合適while(!feof($fp)){ $handle = fopen("hadoop.{$i}.sql","wb"); fwrite($handle,fread($fp,5242880));//切割的塊大小 5m fwrite($file,"hadoop.{$i}.sql/r/n"); fclose($handle); unset($handle); $i++;}fclose ($fp);fclose ($file);echo "ok";
合并代碼
merge.php
<?php$hash = file_get_contents("split_hash.txt"); //讀取分割文件的信息$list = explode("/r/n",$hash);$fp = fopen("hadoop2.sql","ab"); //合并后的文件名foreach($list as $value){ if(!empty($value)) { $handle = fopen($value,"rb"); fwrite($fp,fread($handle,filesize($value))); fclose($handle); unset($handle); }}fclose($fp);echo "ok";
希望本文所述對大家PHP程序設計有所幫助。
新聞熱點
疑難解答
圖片精選