>  기사  >  백엔드 개발  >  PHP로 파일을 읽는 올바른 방법

PHP로 파일을 읽는 올바른 방법

巴扎黑
巴扎黑원래의
2016-11-24 15:05:071478검색

PHP의 다양한 파일 기능을 사용하는 방법을 알아보세요. fopen, fclose 및 feof와 같은 기본 파일 기능을 검토하고 fgets, fgetss 및 fscanf와 같은 읽기 기능에 대해 알아봅니다. 그리고 한두 줄의 코드로 전체 파일을 처리하는 기능을 찾았습니다.

얼마나 많은 방법이 있는지 세어봅시다

PHP와 같은 최신 프로그래밍 언어로 작업하는 즐거움 중 하나는 사용 가능한 옵션이 엄청나게 많다는 것입니다. PHP는 특히 파일 처리와 관련하여 "한 가지 이상의 방법이 있습니다"라는 Perl의 모토를 쉽게 이겼습니다. 하지만 사용할 수 있는 옵션이 너무 많아서 작업에 가장 적합한 도구는 무엇입니까? 물론 실제 답변은 파일 구문 분석 목표에 따라 다르므로 시간을 들여 모든 옵션을 살펴보는 것이 좋습니다.


전통적인 fopen 방법

fopen 방법은 아마도 이전 C 및 C++ 프로그래머에게 가장 익숙할 것입니다. 왜냐하면 여러분이 해당 언어를 사용해 본 적이 있다면 그 언어는 어느 정도 도구에 불과하기 때문입니다. 수년간 그랬어요. 두 방법 중 하나를 사용하면 목록 1에 표시된 대로 fopen(데이터를 읽는 데 사용되는 함수)을 사용하는 표준 방법으로 파일을 연 다음 fclose를 사용하여 닫습니다.

목록 1. fgets를 사용하여 파일을 열고 읽습니다.                 line = fgets($file_handle);
echo $line;
}
fclose($file_handle);

수년간의 프로그래밍 경험을 가진 대부분의 프로그래머는 이러한 기능에 익숙하지만 이 기능을 분석해 보겠습니다. 다음 단계를 효과적으로 수행하세요.
파일을 엽니다. $file_handle은 파일 자체에 대한 참조를 저장합니다.
파일의 끝에 도달했는지 확인하세요.
파일 끝에 도달할 때까지 계속해서 파일을 읽고, 읽은 대로 각 줄을 인쇄합니다.
파일을 닫습니다.

이러한 단계를 염두에 두고 여기서 사용된 각 파일 기능을 검토하겠습니다.

fopen

fopen 함수는 파일에 대한 연결을 생성합니다. fopen은 파일을 여는 것 외에도 URL을 열 수 있기 때문에 "연결 만들기"라고 말합니다: $fh = fopen("http://127.0.0.1/", "r");

This 코드 줄은 위 페이지에 대한 연결을 생성하고 로컬 파일처럼 읽을 수 있게 해줍니다.

참고: fopen에 사용된 "r"은 파일이 읽기 전용으로 열렸음을 나타냅니다. 파일에 데이터를 쓰는 것은 이 기사의 범위를 벗어나므로 다른 모든 옵션을 나열하지는 않겠습니다. 그러나 크로스 플랫폼 호환성을 위해 바이너리 파일에서 읽는 경우 "r"을 "rb"로 변경해야 합니다. 나중에 이에 대한 예를 볼 수 있습니다.

feof

feof 명령은 파일 끝에 도달했는지 여부를 감지하고 True 또는 False를 반환합니다. 목록 1의 루프는 "myfile" 파일의 끝에 도달할 때까지 계속됩니다. 참고: feof는 URL을 읽는 중이고 읽을 데이터가 더 이상 없기 때문에 소켓 시간이 초과되는 경우에도 False를 반환합니다.

fclose

목록 1의 끝으로 건너뛰면 fclose는 fopen과 반대되는 작업을 수행합니다. 즉, 파일이나 URL에 대한 연결을 닫습니다. 이 함수를 실행한 후에는 더 이상 파일이나 소켓에서 어떤 정보도 읽을 수 없습니다.

fgets

목록 1에서 몇 줄 뒤로 이동하면 파일 처리의 핵심, 즉 실제로 파일을 읽는 단계로 넘어갑니다. fgets 함수는 첫 번째 예에서 선택한 무기입니다. 파일에서 데이터 행을 추출하여 문자열로 반환합니다. 그런 다음 데이터를 인쇄하거나 조작할 수 있습니다. 목록 1의 예에서는 전체 파일을 제대로 인쇄합니다.

처리되는 데이터 덩어리의 크기를 제한하기로 결정한 경우 fgets에 매개변수를 추가하여 최대 행 길이를 제한할 수 있습니다. 예를 들어 다음 코드를 사용하여 줄 길이를 80자로 제한합니다. $string = fgets($file_handle, 81);

"참고: 이 함수의 예에서는 이미 fopen과 약간 다른 매개변수를 사용하고 있습니다. 바이너리 데이터로 작업할 때 항상 fopen에 b 옵션을 포함하는 것을 기억하세요. 이 점을 건너뛰면 Microsoft® Windows® 시스템은 새 줄을 다르게 처리하므로 파일을 올바르게 처리하지 못할 수 있습니다. Linux® 시스템(또는 다른 UNIX® 변형)을 다루는 경우에는 이것이 문제가 되지 않을 수 있습니다. 그러나 Windows용으로 개발하지 않더라도 이렇게 하면 플랫폼 간 유지 관리가 향상되므로 따라야 할 좋은 방법입니다.

위 코드는 4,096바이트(4KB)의 데이터를 읽습니다. 참고: 지정된 바이트 수에 관계없이 fread는 8,192바이트(8KB) ​​이상을 읽지 않습니다.

다음 코드는 파일 크기가 8KB 이하라고 가정하고 전체 파일을 문자열로 읽어야 합니다. $fh = fopen("myfile", "rb");
$data = fread($fh, filesize("myfile"));
fclose($fh);

if file 길이가 이 값보다 크면 나머지는 루프를 통해서만 읽을 수 있습니다.

fscanf

문자열 처리로 돌아가서, fscanf는 전통적인 C 파일 라이브러리 기능도 따릅니다. 익숙하지 않다면 fscanf는 파일의 필드 데이터를 변수로 읽어옵니다. list ($field1, $field2, $field3) = fscanf($fh, "%s %s %s");

이 함수에서 사용하는 형식 문자열은 여러 위치(예: PHP. net)이므로 여기서는 자세히 설명하지 않겠습니다. 문자열 형식 지정은 매우 유연합니다. 모든 필드가 함수의 반환 값에 배치된다는 점은 주목할 가치가 있습니다. (C에서는 모두 인수로 전달됩니다.)

fgetss

fgetss 함수는 기존 파일 함수와 다르며 PHP의 성능을 더 잘 이해할 수 있도록 해줍니다. 이 함수는 fgets 함수와 유사하게 작동하지만 발견된 모든 HTML 또는 PHP 태그를 제거하고 일반 텍스트만 남깁니다. 아래 표시된 HTML 파일을 봅니다.

목록 2. 샘플 HTML 파일                                                                      🎜>              ~                                       ;


그런 다음 fgetss 함수를 통해 필터링합니다.

목록 3. fgetss 사용                                                                                            >         );
}
fclose($file_handle);



다음은 출력입니다. 내 제목

"너에게 고통을 줄 사람은 아무도 없으니까"
라는 뜻을 이해한다면 미국 밴드



fpassthru 기능을 너무 많이 듣는다는 뜻입니다
🎜>
파일을 어떻게 읽어도 fpassthru를 사용하여 나머지 데이터를 표준 출력 채널로 덤프할 수 있습니다. fpassthru($fh);


또한 이 함수는 데이터를 인쇄하므로 데이터를 가져오기 위해 변수를 사용할 필요가 없습니다.

비선형 파일 처리: 접근 건너뛰기

물론 위 기능은 파일의 순차 읽기만 허용합니다. 더 복잡한 파일에서는 파일의 다른 부분으로 앞뒤로 이동해야 할 수도 있습니다. 이것이 fseek가 유용한 곳입니다. fseek($fh, 0);


위의 예는 파일의 시작 부분으로 다시 이동합니다. 완전히 반환할 필요가 없다면 반환을 킬로바이트로 설정할 수 있습니다. 그런 다음 다음과 같이 작성할 수 있습니다: fseek($fh, 1024);


PHP V4.0부터 시작하면 몇 가지가 있습니다. 기타 옵션. 예를 들어 현재 위치에서 100바이트 앞으로 이동해야 하는 경우 다음을 사용해 볼 수 있습니다. fseek($fh, 100, SEEK_CUR);


마찬가지로 다음 코드를 사용하여 점프할 수 있습니다. 뒤로 100바이트 이동: fseek($fh, -100, SEEK_CUR);


파일이 끝나기 전에 100바이트 뒤로 이동해야 하는 경우 SEEK_END를 사용해야 합니다. fseek($fh, -100, SEEK_END);


새 위치에 도달한 후 fgets, fscanf 또는 기타 방법을 사용하여 데이터를 읽을 수 있습니다.

참고: fseek는 URL을 참조하는 파일 처리에 사용할 수 없습니다.


전체 파일 추출

이제 PHP의 보다 독특한 파일 처리 기능 중 일부인 한두 줄로 많은 양의 데이터를 처리하는 기능을 살펴보겠습니다. 예를 들어 파일을 추출하고 해당 내용 전체를 웹 페이지에 표시하는 방법은 무엇입니까? 좋습니다. 루프를 사용하는 fgets의 예를 보았습니다. 하지만 이 과정을 어떻게 더 쉽게 만들 수 있을까요? 전체 파일을 문자열에 넣는 fgetcontents를 사용하면 프로세스가 매우 쉽습니다. $my_file = file_get_contents("myfilename");
echo $my_file;


최선의 방법은 아니지만 이 명령은 다음과 같이 더 간결하게 작성할 수 있습니다. echo file_get_contents("myfilename ") ;

이 기사는 로컬 파일 작업에 중점을 두고 있지만 이러한 기능을 사용하여 다른 웹페이지를 추출, 에코 및 구문 분석할 수도 있다는 점은 주목할 가치가 있습니다. echo file_get_contents("http://127.0.0.1/");

이 명령은 $fh = fopen("http://127.0.0.1/", "r");fpassthru($fh);


이 명령을 보고 '그래도 너무 노력이 많이 들구나'라고 생각하게 될 것입니다. PHP 개발자는 귀하의 의견에 동의합니다. 따라서 위 명령은 다음과 같이 단축될 수 있습니다: readfile("http://127.0.0.1/");

readfile 함수는 파일이나 웹 페이지의 전체 내용을 기본 출력 버퍼에 덤프합니다. 기본적으로 이 명령은 실패할 경우 오류 메시지를 인쇄합니다. 이 동작을 방지하려면(필요한 경우) 다음을 시도하십시오. @readfile("http://127.0.0.1/");

물론 파일을 구문 분석해야 하는 경우 file_get_contents에서 반환된 단일 문자열 다소 부담스러울 수도 있습니다. 첫 번째 본능은 Split() 함수를 사용하여 분할하는 것일 수 있습니다. $array = Split("n", file_get_contents("myfile"));

그런데 이 작업을 수행하는 좋은 함수가 이미 있는데 왜 이 모든 문제를 해결해야 합니까? PHP의 file() 함수는 이 작업을 한 단계로 수행합니다. 즉, 여러 줄로 나누어진 문자열 배열을 반환합니다. $array = file("myfile");

위의 두 예에는 약간의 차이가 있다는 점에 유의해야 합니다. Split 명령은 새 줄을 제거하지만 file 명령을 사용할 때(fgets 명령과 마찬가지로) 새 줄은 여전히 ​​배열의 문자열에 추가됩니다.

그러나 PHP의 힘은 그 이상입니다. parse_ini_file을 사용하면 단일 명령으로 전체 PHP 스타일 .ini 파일을 구문 분석할 수 있습니다. parse_ini_file 명령은 목록 4에 표시된 것과 유사한 파일을 허용합니다.

목록 4. 샘플 .ini 파일      
; 댓글
[개인 정보]
name = "King Arthur"
quest = 성배를 찾으려면
좋아하는 색상 = Blue

[추가 항목]
Samuel Clemens = Mark Twain
Caryn Johnson = Whoopi Goldberg

다음 명령은 이 파일을 배열로 덤프한 다음 배열을 인쇄합니다. $ file_array = pars_ini_file("holy_grail.ini");
print_r $file_array;

다음 출력이 결과입니다.

목록 5. 출력                               🎜> [이름] => 아서왕
[퀘스트] => 성배를 찾으러
[좋아하는 색] => 파란색
[사무엘 클레멘스] => 마크 트웨인
[캐린 존슨] => 우피 골드버그
)

물론 이 명령이 부분을 병합한다는 것을 알 수 있습니다. 이는 기본 동작이지만 부울 변수인 pars_ini_file: process_sections에 두 번째 인수를 전달하여 쉽게 수정할 수 있습니다. process_sections를 True로 설정합니다. $file_array = pars_ini_file("holy_grail.ini", true);
print_r $file_array;

다음과 같은 출력을 얻게 됩니다.

목록 6. 출력 >(
[개인정보] => 배열
(
[이름] => 아서 왕
[퀘스트] => 성배를 찾으러
[좋아하는 색] = > 파란색
)

[추가 항목] => 배열
(
[Samuel Clemens] => Mark Twain
[Caryn Johnson] => Whoopi Gold berg
      )

)

PHP는 데이터를 쉽게 구문 분석할 수 있는 다차원 배열에 저장합니다.

이것은 PHP 파일 처리에 있어서 빙산의 일각에 불과합니다. tidy_parse_file 및 xml_parse와 같은 더 복잡한 함수는 HTML 및 XML 문서를 각각 처리하는 데 도움이 될 수 있습니다. 이러한 특수 기능의 사용에 대한 자세한 내용은 참고자료를 참조하세요. 이러한 유형의 파일을 다루는 경우 이러한 참조는 살펴볼 가치가 있지만 이 문서에서 설명된 모든 파일 유형을 지나치게 생각하지 않고 지금까지 다룬 일반 규칙을 다루는 기능을 사용하는 데 유용한 몇 가지 참조가 있습니다.

모범 사례

프로그램의 모든 것이 계획대로 실행될 것이라고 가정하지 마십시오. 예를 들어, 찾고 있는 파일이 이동되었다면 어떻게 될까요? 권한이 변경되어 해당 내용을 읽을 수 없으면 어떻게 되나요? file_exists 및 is_readable을 사용하여 이러한 문제를 미리 확인할 수 있습니다.

목록 7. file_exists 및 is_readable 사용                                                                                               > 🎜>그러나 실제로 이러한 코드를 사용하는 것은 너무 번거로울 수 있습니다. fopen의 반환 값을 처리하는 것이 더 간단하고 정확합니다. if ($fh = fopen($filename, "r")) {
# 처리
fclose($fh);
}

fopen은 실패 시 False를 반환하므로 이는 다음과 같습니다. 파일이 성공적으로 열린 경우에만 파일 처리가 수행되는지 확인하십시오. 물론 파일이 존재하지 않거나 읽을 수 없는 경우에는 음수 반환 값을 기대할 수 있습니다. 이를 통해 검사를 통해 발생할 수 있는 모든 문제를 확인할 수 있습니다. 또한 열기에 실패하면 프로그램을 종료하거나 프로그램에 오류 메시지가 표시되도록 할 수 있습니다.

fopen 함수와 마찬가지로 file_get_contents, file 및 readfile 함수는 열기에 실패하거나 파일 처리에 실패하면 모두 False를 반환합니다. fgets, fgetss, fread, fscanf 및 fclose 함수도 오류 시 False를 반환합니다. 물론 fclose를 제외한 모든 함수의 반환 값을 처리했을 수도 있습니다. fclose를 사용하면 파일 처리가 정상적으로 닫히지 않더라도 아무 작업도 수행되지 않으므로 일반적으로 fclose의 반환 값을 확인할 필요가 없습니다.

선택은 당신의 몫입니다

PHP에는 파일을 읽고 구문 분석하는 효율적인 방법이 부족하지 않습니다. fread와 같은 일반적인 기능이 대부분의 경우 최선의 선택일 수도 있고, readfile이 작업에 적합할 때 readfile의 단순성에 더 매력을 느낄 수도 있습니다. 실제로 수행되는 작업에 따라 다릅니다.

많은 양의 데이터를 처리하는 경우 fscanf는 분할 및 sprintf 명령과 함께 파일을 사용하는 것보다 그 가치가 입증되고 더 효율적입니다. 반대로, 약간만 수정하여 많은 양의 텍스트를 에코하려면 file, file_get_contents 또는 readfile을 사용하는 것이 더 적절할 수 있습니다. 임시 프록시 서버를 캐싱하거나 생성하기 위해 PHP를 사용하는 경우가 이에 해당할 수 있습니다.

PHP는 파일 처리를 위한 다양한 도구를 제공합니다. 이러한 도구에 대해 자세히 알아보고 작업 중인 프로젝트에 가장 적합한 도구가 무엇인지 알아보세요. 이미 많은 옵션이 있으므로 이를 활용하고 PHP에서 파일 작업을 즐겨보세요.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.