PHP에서 텍스트를 읽는 방법

藏色散人
풀어 주다: 2023-02-28 15:12:01
원래의
4144명이 탐색했습니다.

PHP에서 텍스트를 읽는 방법

php 텍스트를 읽는 방법은 무엇인가요?

php에서 파일 내용을 읽는 여러 가지 방법

1.fread

  string fread ( int $handle , int $length )
로그인 후 복사

fread( )은 핸들이 가리키는 파일에서 최대 길이 바이트를 읽습니다. 이 함수는 length 바이트까지 읽은 후, EOF에 도달한 경우, 또는 (네트워크 스트림의 경우) 패킷을 사용할 수 있는 경우 또는 (사용자 공간 스트림을 연 후) 8192바이트를 읽은 후 호출됩니다. 어떤 조건이 먼저 발생하는지에 따라 다릅니다.

권장 사항: "PHP Tutorial"

 fread()는 읽은 문자열을 반환하고, 오류가 발생하면 FALSE를 반환합니다.

<?php
    $filename = "/usr/local/something.txt";
    $handle = fopen($filename, "r");//读取二进制文件时,需要将第二个参数设置成&#39;rb&#39;
    
    //通过filesize获得文件大小,将整个文件一下子读到一个字符串中
    $contents = fread($handle, filesize ($filename));
    fclose($handle);
?>
로그인 후 복사

읽어올 파일이 로컬 일반 파일이 아닌 원격 파일이나 스트림 파일인 경우에는 filesize로 해당 파일의 크기를 얻을 수 없으므로 이 방법을 사용할 수 없습니다. 이때 파일의 끝을 읽었는지 여부를 확인하려면 feof() 또는 fread()의 반환 값을 사용해야 합니다.

예:

<?php
    $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
    $content = &#39;&#39;;
    while(!feof($handle)){
        $content .= fread($handle, 8080);
    }
    echo $content;
    fclose($handle);
?>
로그인 후 복사

또는

<?php
    $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
    $content = &#39;&#39;;
    while(false != ($a = fread($handle, 8080))){//返回false表示已经读取到文件末尾
        $content .= $a;
    }
    echo $content;
    fclose($handle);
?>
로그인 후 복사

2.fgets

  string fgets ( int $handle [, int $length ] )
로그인 후 복사
#🎜🎜 # fgets()는 핸들이 가리키는 파일에서 한 줄을 읽고 최대 길이 - 1바이트의 문자열을 반환합니다. 개행 문자(반환 값에 포함됨), EOF 또는 길이 - 1바이트를 읽었을 때(둘 중 먼저 발생하는 것) 중지됩니다. 길이를 지정하지 않으면 기본값은 1K 또는 1024바이트입니다.

<?php
    $handle = fopen(&#39;./file.txt&#39;, &#39;r&#39;);
    while(!feof($handle)){
        echo fgets($handle, 1024);
    }
    fclose($handle);
?>
로그인 후 복사

 참고: PHP 4.2.0부터 길이 매개변수는 선택사항입니다. 생략할 경우 행 길이는 1024로 간주됩니다. PHP 4.3부터 길이를 생략하면 줄 끝까지 스트림에서 계속 읽혀집니다. 파일 내 라인의 대부분이 8KB보다 큰 경우 스크립트에서 최대 라인 길이를 지정하는 것이 리소스 활용에 더 효율적입니다. PHP 4.3부터 이 함수는 바이너리 파일과 함께 사용해도 안전합니다. 이전 버전은 그렇지 않습니다.

3.fgetss

  string fgetss ( resource $handle [, int $length [, string $allowable_tags ]] )
로그인 후 복사

fgets와 동일하지만 fgetss는 읽기 텍스트에서 HTML 및 PHP 태그를 제거하려고 시도합니다. 선택적인 세 번째 매개변수를 사용하여 태그를 지정할 수 있습니다. 제거되지 않습니다.

<?php
    $handle = fopen(&#39;./file.txt&#39;, &#39;r&#39;);
    while(!feof($handle)){
        echo fgetss($handle, 1024, &#39;<br>&#39;);
    }
    fclose($handle);
?>
로그인 후 복사

4.file

  array file ( string $filename [, int $use_include_path [, resource $context ]] )
로그인 후 복사

배열의 각 항목은 파일의 한 줄에 해당합니다. 줄바꿈 포함. 줄 종결자가 필요하지 않은 경우 rtrim() 함수를 사용하여 개행 문자를 필터링할 수 있습니다.

<?php
    $a = file(&#39;./file.txt&#39;);
    foreach($a as $line => $content){
        echo &#39;line &#39;.($line + 1).&#39;:&#39;.$content;
    }
?>
로그인 후 복사

5.readfile

  int readfile ( string $filename [, bool $use_include_path [, resource $context ]] )
로그인 후 복사

파일을 읽고 출력 버퍼에 씁니다. 파일에서 읽은 바이트 수를 반환합니다. 오류 시 FALSE를 반환하고 @readfile()로 호출하지 않으면 오류 메시지를 표시합니다.

<?php
    $size = readfile(&#39;./file.txt&#39;);
    echo $size;
?>
로그인 후 복사

6.file_get_contents

  string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )
로그인 후 복사

파일을 문자열로 읽어옵니다. 세 번째 매개변수 $context는 원격 파일에 액세스할 때 시간 초과 설정 등 일부 매개변수를 설정하는 데 사용할 수 있습니다.

게다가 위 함수들에 비해 file_get_contents의 성능이 훨씬 좋기 때문에 file_get_contents에 우선순위를 주어야 합니다. 하지만 readfile은 fopen을 호출할 필요가 없기 때문에 file_get_contents(?)보다 성능이 더 좋은 것 같습니다.

<?php 
    $ctx = stream_context_create(array( 
        &#39;http&#39; => array( 
            &#39;timeout&#39; => 1    //设置超时
            ) 
        ) 
    ); 
    echo file_get_contents("http://www.baidu.com/", 0, $ctx); 
?>
로그인 후 복사

7.fpassthru

   int fpassthru ( resource $handle )
로그인 후 복사

주어진 파일 포인터를 현재 위치에서 EOF까지 읽고 결과를 출력 버퍼에 씁니다.

<?php 
    header("Content-Type:text/html;charset=utf-8"); 
    $handle = fopen(&#39;./test2.php&#39;, &#39;r&#39;);
    fseek($handle, 1024);//将指针定位到1024字节处
    fpassthru($handle);
?>
로그인 후 복사

몇 가지 참고 사항:

 1. 시스템이 그렇지 않은 경우에도 바이너리 파일을 처리할 때 b 플래그를 사용하는 것이 좋습니다. 필요하면 스크립트의 이식성을 높일 수 있습니다. ​

 2.allow_url_fopen 옵션은 파일과 같은 URL 개체에 액세스할 수 있도록 fopen 캡슐화 프로토콜의 URL 형식을 활성화합니다. 기본 캡슐화 프로토콜은 ftp 및 http 프로토콜을 사용하여 원격 파일에 대한 액세스를 제공합니다. zlib와 같은 일부 확장 라이브러리는 더 많은 캡슐화 프로토콜을 등록할 수 있습니다. 보안상의 이유로 이 옵션은 php.ini에서만 설정할 수 있습니다.

 3. 특수 문자(예: 공백)가 포함된 URL을 열려면 URL 인코딩에 urlencode()를 사용해야 합니다.

위 내용은 PHP에서 텍스트를 읽는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
php
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿