ホームページ バックエンド開発 PHPチュートリアル PHPでの大容量ファイルの読み込みと分割例を詳しく解説

PHPでの大容量ファイルの読み込みと分割例を詳しく解説

Jul 25, 2016 am 09:11 AM

php读取与分割大文件

在php中,对于文件的读取时,最快捷的方式莫过于使用一些诸如file、file_get_contents之类的函数,简单几行代码即可实现功能。 但当所操作的文件是一个比较大的文件时,这些函数可能就显的力不从心, 下面将从一个需求入手来说明对于读取大文件时,常用的操作方法。 需求如下: 现有一个1G左右的日志文件,大约有500多万行, 用php返回最后几行的内容。

实现方法: 1. 直接采用file函数来操作 注:由于 file函数是一次性将所有内容读入内存,而php为了防止一些写的比较糟糕的程序占用太多的内存而导致系统内存不足,使服务器出现宕机,所以默认情况下 限制只能最大使用内存16M,这是通过php.ini里的memory_limit = 16M来进行设置,这个值如果设置-1,则内存使用量不受限制。 下面是一段用file来取出这具文件最后一行的代码. 整个代码执行完成耗时 116.9613 (s).

  1. $fp = fopen($file, "r");
  2. $num = 10;
  3. $chunk = 4096;
  4. $fs = sprintf("%u", filesize($file));
  5. $max = (intval($fs) == PHP_INT_MAX) ? PHP_INT_MAX : filesize($file);
  6. for ($len = 0; $len < $max; $len += $chunk) {
  7. $seekSize = ($max - $len > $chunk) ? $chunk : $max - $len;
  8. fseek($fp, ($len + $seekSize) * -1, SEEK_END);
  9. $readData = fread($fp, $seekSize) . $readData;
  10. if (substr_count($readData, "\n") >= $num + 1) {
  11. preg_match("!(.*?\n){".($num)."}$!", $readData, $match);
  12. $data = $match[0];
  13. break;
  14. }
  15. }
  16. fclose($fp);
  17. echo $data;
复制代码

我机器是2个G的内存,当按下F5运行时,系统直接变灰,差不多20分钟后才恢复过来,可见将这么大的文件全部直接读入内存,后果是多少严重,所以不在万不得以,memory_limit这东西不能调得太高,否则只有打电话给机房,让reset机器了. 2.直接调用linux的tail命令来显示最后几行 在linux命令行下,可以直接使用tail -n 10 access.log很轻易的显示日志文件最后几行,可以直接用php来调用tail命令,执行php代码如下. 整个代码执行完成耗时 0.0034 (s)

  1. file = 'access.log';
  2. $file = escapeshellarg($file); // 对命令行参数进行安全转义
  3. $line = `tail -n 1 $file`;
  4. echo $line;
复制代码

3. 直接使用php的fseek来进行文件操作 这种方式是最为普遍的方式,它不需要将文件的内容全部读入内存,而是直接通过指针来操作,所以效率是相当高效的.在使用fseek来对文件进行操作时,也有多种不同的方法,效率可能也是略有差别的,下面是常用的两种方法. 方法一: 首先通过fseek找到文件的最后一位EOF,然后找最后一行的起始位置,取这一行的数据,再找次一行的起始位置,再取这一行的位置,依次类推,直到找到了$num行。 实现代码如下 整个代码执行完成耗时 0.0095 (s)

  1. function tail($fp,$n,$base=5)
  2. {
  3. assert($n>0);
  4. $pos = $n+1;
  5. $lines = array();
  6. while(count($lines)< =$n){
  7. try{
  8. fseek($fp,-$pos,SEEK_END);
  9. } catch (Exception $e){
  10. fseek(0);
  11. break;
  12. }
  13. $pos *= $base;
  14. while(!feof($fp)){
  15. array_unshift($lines,fgets($fp));
  16. }
  17. }
  18. return array_slice($lines,0,$n);
  19. }
  20. var_dump(tail(fopen("access.log","r+"),10));
复制代码

方法二: 还是采用fseek的方式从文件最后开始读,但这时不是一位一位的读,而是一块一块的读,每读一块数据时,就将读取后的数据放在一个buf里,然后通过换行符(\n)的个数来判断是否已经读完最后$num行数据. 整个代码执行完成耗时 0.0009(s).

  1. $fp = fopen($file, "r");
  2. $line = 10;
  3. $pos = -2;
  4. $t = " ";
  5. $data = "";
  6. while ($line > 0) {
  7. while ($t != "\n") {
  8. fseek($fp, $pos, SEEK_END);
  9. $t = fgetc($fp);
  10. $pos --;
  11. }
  12. $t = " ";
  13. $data .= fgets($fp);
  14. $line --;
  15. }
  16. fclose ($fp);
  17. echo $data
コードをコピー

方法 3: コード全体の実行には 0.0003 秒かかります

  1. ini_set('memory_limit','-1');
  2. $file = 'access.log';
  3. $data = file($file);
  4. $line = $data[ count($data)-1];
  5. echo $line;
コードをコピー


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 Apr 03, 2025 am 12:04 AM

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムの再起動後にUnixSocketの権限を自動的に設定する方法は? システムの再起動後にUnixSocketの権限を自動的に設定する方法は? Mar 31, 2025 pm 11:54 PM

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

PHPにおける後期静的結合の概念を説明します。 PHPにおける後期静的結合の概念を説明します。 Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? Apr 01, 2025 pm 03:12 PM

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

phpstormでCLIモードをデバッグする方法は? phpstormでCLIモードをデバッグする方法は? Apr 01, 2025 pm 02:57 PM

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

フレームワークセキュリティ機能:脆弱性から保護します。 フレームワークセキュリティ機能:脆弱性から保護します。 Mar 28, 2025 pm 05:11 PM

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

See all articles