>  기사  >  백엔드 개발  >  PHP 파일 쓰기 및 그래픽 및 텍스트 세부 정보 읽기

PHP 파일 쓰기 및 그래픽 및 텍스트 세부 정보 읽기

墨辰丷
墨辰丷원래의
2018-05-22 14:16:251374검색

이 글은 주로 PHP 파일에서 그래픽과 텍스트를 작성하고 읽는 방법을 소개합니다. 관심 있는 친구들이 참고하면 도움이 될 것입니다. 글 개요:

1. 파일 읽기 및 쓰기 구현의 기본 아이디어

2. fopen 메소드를 사용하여 파일을 엽니다

3. 파일 읽기 및 파일 쓰기 작업

IV. fclose 메소드를 사용하여 파일을 닫습니다

5. 파일 포인터의 움직임

6. Windows 및 UNIX

1에서 캐리지 리턴 및 줄 바꿈. 파일 읽기 및 쓰기 구현의 기본 아이디어:

1. fopen 메소드를 통해 파일을 엽니다: $fp =fopen(/*매개변수, 매개변수*/), fp는 리소스 유형
2입니다. 파일 읽기 또는 파일 쓰기 작업을 수행합니다(여기서 사용된 함수는 1에서 반환된 $fp를 매개 변수로 사용합니다)
3. 파일을 닫으려면 fclose($fp)를 호출하세요.

둘: fopen 메서드를 사용하여 파일을 엽니다. file

fopen(파일 경로 [문자열], 열기 모드 [문자열])

f35d6e602fd7d0f0edfa6f7d103c1b57fopen의 첫 번째 매개 변수는 파일 경로입니다
파일 경로 작성 방법: 절대 경로 1개, 상대 경로 2개 path

1 절대 경로:

Windows에서 작업하는 친구들은 익숙할 것입니다. Windows 아래의 경로 구분 기호는 "/" 대신 ""이지만 경로를 작성할 때 사용할 수 없습니다. 공식 "" 구분 기호

경로를 "" 구분 기호로 쓰면 어떻게 될까요?


<?php
   $fp = fopen("C:\wamp64\www\text.txt",&#39;w&#39;);
?>


실행 후 경로 매개변수가 유효하지 않다는 오류가 보고됩니다.


따라서 구분 기호 ""를 "/"로 바꿔야 합니다.


<?php
  $fp = fopen("C:/wamp64/www/text.txt",&#39;w&#39;);
?>


Runtime 매개변수가 유효함을 나타내는 오류가 보고되지 않습니다.

【참고】fopen 함수는 "" 구분 기호를 인식할 수 없습니다. ""를 사용하려면 다음과 같이 이스케이프를 사용하세요. "C:\wamp64\www\text.txt" 쓰기 방법 또한 가능하며 기능을 이해할 수 있으며 오류가 보고되지 않습니다. 하지만 그럼에도 불구하고 ""를 사용하는 것은 권장하지 않습니다. OS(mac)에서는 "/"만 인식할 수 있고 ""

이 섹션의 결론: "를 계속 사용하는 것이 좋습니다. /"를 구분자로

2. 상대경로 :

앞 절에서 절대경로 작성방법을 소개했지만 이로 인해 또 다른 문제가 발생하는데, 서버의 디렉터리 구조가 크게 바뀔 수 있다는 점이다. 이때 , 모든 절대 경로를 다시 작성해야 하는 것으로 나타났습니다. 예를 들어 내 컴퓨터의 대상 파일 경로는 C:/wamp64/www/text.txt입니다. www 폴더 이름을 penghuwan으로 바꾸면 어떻게 되나요? 원래 작성된 경로 매개변수가 유효하지 않습니다. 그래서 우리는 상대 경로 작성 방법을 소개했습니다:


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;w&#39;);
?>


• $_SERVER는 PHP의 슈퍼 전역 변수입니다(코드 어디에서나 접근 가능, 유형은 배열임). $_SERVER[ 'DOCUMENT_ROOT'] 서버의 기본 루트 디렉터리로 이동

서버의 기본 루트 디렉터리는 php.ini를 통해 수정할 수 있습니다(직접 Baidu할 수 있음)

• $_SERVER['DOCUMENT_ROOT'] 여기서는 동일합니다. to C:/wamp64/www

이 섹션의 결론: 상대 경로를 사용하는 것이 좋습니다

2cc198a1d5eb0d3eb508d858c9f5cbdbfopen의 두 번째 매개변수는 개방형 모드입니다

열림 모드를 설정한 후, 후속 읽기 및 쓰기 작업에 대한 권한을 설정하는 것과 동일합니다.

가장 기본 모드:

"r": 파일을 읽을 수만 있고 파일을 쓸 수 없음(쓰기 작업은 무시됨)
"w": 파일 쓰기만 가능, 파일 읽기 불가(읽기 작업은 무시됨)
"a": 파일만 추가합니다. "w"와 유사합니다. 차이점은 "w"는 원본 내용을 삭제하고 "a"는 원본 내용을 삭제하지 않는다는 것입니다. , 내용만 추가합니다


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;w&#39;);
  fwrite($fp,&#39;在写模式下写入&#39;);
  fclose($fp);
?>


쓰기 작업에 대한 권한을 설정한 후 파일을 정상적으로 쓸 수 있습니다

실행 후 C:/wamp64/www/text.txt 열기:

이번에는 권한을 읽기 전용으로 설정하고 텍스트 쓰기를 시도합니다: '읽기 전용 모드로 쓰기'


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
  fwrite($fp,&#39;在读模式下写入&#39;);
  fclose($fp);
?>


실행 후 C:/wamp64/www/text.txt를 열고 다음을 찾습니다. 파일 내용이 변경되지 않았습니다. 해당 권한을 설정하지 않았으며 작업이 무시되었음을 나타냅니다

关于打开模式的网络资料,我想大家最可能找到的是这张表:(图来自W3C)

很全面,但我觉得这张表对新手有些不太友好,让人看后不知多云。 r是只读,w是只写(原来有的内容全删除),a是追加(不删除原有内容),这都好理解。

但r+,w+,和a+的区别和联系讲的实在太模糊了呀。 这里我就想详细地讲一下r+,w+,和a+三者的区别和联系:

首先r+,w+,和a+都是可读可写的,读取时的方式是一样的,关键在于写入方式的不同:

r+: 从文件[头部][覆盖]原有内容 ([不删除]原有内容);

a+:从文件[尾部][追加]内容 ([不删除]原有内容);

w+:[完全删除]原有内容,然后[再添加]新的内容

下面我依次演示上述的结论,首先我们没有写入的时候文本是”I am initialized value”(意为我是初始值)

采用r+模式写入文本“r+ mode”


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r+&#39;);
  fwrite($fp,&#39;r+ mode&#39;);
  fclose($fp);
?>


运行后再打开文本,发现“I am in”被“r+ mode”覆盖了:

采用a+模式写入文本“a+ mode”

基于”I am initialized value”的初始文本我们运行以下代码:


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;a+&#39;);
  fwrite($fp,&#39;a+ mode&#39;);
  fclose($fp);
?>



I am initialized value没有被删除和覆盖,而是在后面追加了a+ mode的这一段新文本

运行多次后:

•采用w+模式写入文本“w+ mode”

基于”I am initialized value”的初始文本我们运行以下代码:


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;w+&#39;);
  fwrite($fp,&#39;w+ mode&#39;);
  fclose($fp);
?>


运行后,我们发现”I am initialized value”已经被删除了,然后才加上了“w+ mode”这段新文本

【注意】r+,a+,w+还有一个区别是a+,w+在文件不存在时则创建文件,r+文件不存在时报错

【吐槽】:关于r+和w+,a+的区别,我找了网络上,包括W3C和各种博客文章以及那本“PHP圣经”上的各种资料,发现都是一笔带过去的,这也是我写这篇文章的原因

三.文件读取和文件写入操作

先说说几个比较重要的函数:

file_exists():判断文件是否存在,返回布尔值

filesize():判断一个文件大小,返回文件的字节数,为整型数字

unlink():删除一个文件

写入文件

fwrite(资源文件对象[string],写入方式[string]),资源文件对象即为fopen方法返回的参数,为Resource类型,写入方式可以是w(或者w+,a+,r+)

已经有上面的例子,这里就不放demo了

读取文件

这是我们要读取的文件内容:


读取文件的方式有以下几种:

1.一次读取一个字节的数据 fgetc()

2.一次读取指定的字节数的数据 fread()

3.一次读取一行数据 fgets()/fgetcsv()

4.一次读完全部数据 fpassthru()/ file()

1. 一次读取一个字节 —— 通过fgetc()获取单个字节


<?php
   $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
   $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);//打开文件
   if(file_exists("$DOCUMENT_ROOT/text.txt")){//当文件存在时,才读取内容
     while(!feof($fp)){//判断文件指针是否到达末尾
        $c = fgetc($fp);//每执行一次fgetc(),文件指针就向后移动一位
        echo $c;//输出获取到的字节
      }
    }
   fclose($fp);//关闭文件
?>


运行:

【注意】:无论是按文本格式输入输出还是按二进制格式输出,fgetc()每次获取的是一个字节而不是一个字符

上面的例子中我们是逐个输出,现在让我们只做一次输出,看看结果怎样:


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
  echo fgetc($fp);//只做一次输出
  close($fp);
?>


运行结果如下,我们得到的不是汉字“我”,而是一个乱码,其实这个乱码就是一个字节


<?php
   $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
   $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
   echo fgetc($fp);//连续做三次输出
   echo fgetc($fp);
   echo fgetc($fp);
   fclose($fp);
?>


2.一次读取多个字节 ——通过fread()方法:


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
  echo fread($fp, 3);//一次输出三个字节即一个汉字字符(UTF-8)
  fclose($fp);
?>


运行结果:


改成:


echo fread($fp, 6);


运行结果如下,输出了6个字节也即两个汉字字符(UTF-8)

3.一次读取一行——通过fgets()获取一行内容


<?php
    $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;]
    $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);//打开文件
    if(file_exists("$DOCUMENT_ROOT/text.txt")){//当文件存在时,才读取内容
     while(!feof($fp)){//判断文件指针是否到达末尾
       $line = fgets($fp);//返回一行文本,并将文件指针移动到下一行头部
       echo $line."<br/>";//输出获取到的一行文本
     }
    }
    fclose($fp);//关闭文件
?>


fgets()其实还有第二个参数,这个参数规定了每一行能读取的最大字节数(注意是字节数不是字符数):

【注意】在UTF-8编码下汉字3字节,字母1字节

下面我修改上面的一行,代码,使获取的每一行最大字符数为3(也即字节数为9)


$line = fgets($fp,10);


Demo:

【注意】:这里我fgets()里第二个参数为10,为什么是10呢?因为

1.这里的长度是按字节数算的

2.一个汉字占3个字节。fgets($fp,10)代表一次最多读取10 - 1 = 9字节

4.一次读完全部文件 ——fpassthru() or file()?

fpassthru()将读取文件并直接输出(无处理过程)


<?php
   $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
   $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
   fpassthru($fp);
   fclose($fp);
?>


运行结果:

【注意】这里需要注意一点的是,我们并没有从fpassthru($fp)获取到返回值然后echo到页面上去,也就是说这个方法是会强制输出获取的内容的,而并不是像之前例子的方法那样返回文本,允许我们保存到变量中才将其输出

将读取到的全部内容保存到一个数组中,每个数组元素为一行的内容——fille()


<?php
  $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
  $file_array = file("$DOCUMENT_ROOT/text.txt");//取到文件数组
  foreach ($file_array as $value) {//输出数组元素
    echo $value."<br/>";
  }
?>


【注意】:这里我们并不需要写fopen和fclose哦!也就是说file()方法已经帮我们做了这一步了

四.使用fclose方法关闭文件

fclose()将返回一个布尔值,成功关闭为true,关闭失败为false(失败的情况很少出现,可不考虑)

是否打开文件后一定要关闭?

1即使不手写fclose,在PHP脚本执行结束后,也会自动关闭文件的

2但在一个长时间执行的脚本中,如果不写关闭文件的fclose(),在文件加锁的情况下会造成操作的阻塞,所以,写fclose是个好习惯

五.文件指针的移动

我们上面调用的读取文件的函数,其实都是基于文件指针去打印的,每读取一段字节内容,文件指针就向后移动一段字节长度,直到被读取的文件最大字节长度为止


<?php
     $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
     function print_file_pointer($fp){//定义一个打印文件指针位置的函数
       echo " <br/>//此时文件指针的位置:";
       echo ftell($fp)."<br/>";
     }
     $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
     echo fgetc($fp);//通过fgetc连续输出三个字节
     echo fgetc($fp);
     echo fgetc($fp);
     print_file_pointer($fp);//打印此刻文件指针的位置
     
     echo fread($fp,6);//通过fread一次输出6字节
     print_file_pointer($fp);//打印此刻文件指针的位置
     
     echo fgets($fp); //通过fgets输出一整行
     print_file_pointer($fp);//打印此刻文件指针的位置
     
     fpassthru($fp); //一次性输出全部内容
     print_file_pointer($fp);//打印此刻文件指针的位置
     
     fseek($fp, 33);//使文件指针移动到33字节位置
     print_file_pointer($fp);//打印此刻文件指针的位置
     
     rewind($fp);//使文件指针移动到0字节位置(初始位置)
     print_file_pointer($fp);//打印此刻文件指针的位置
$fclose($fp);
?>


Demo:

所以我们需要正确理解fgets(),fpassthru()这些函数的作用:

fgets():从当前文件指针的位置到本行结束的数据,而不是一定输出一整行

fpassthru():从当前文件指针的位置到全部内容结束的数据,而不是一定输出所有的数据

但在这里你可能会有疑问:为什么输出“湖湾”后的指针位置会是17而不是15呢?按理说输出“我叫彭湖湾”这5个汉字一共占3*5 = 15个字节,多出来的17 - 15 =2字节是什么呢?

多出来的两个字节是windows下的回车换行符\n\r

\n是换行,占一字节,\r是回车,占一字节,在六中我将会介绍

六.Windows和UNIX下的回车和换行


<?php
   $DOCUMENT_ROOT = $_SERVER[&#39;DOCUMENT_ROOT&#39;];
   $fp = fopen("$DOCUMENT_ROOT/text.txt",&#39;r&#39;);
   while(!feof($fp)){
    echo fgets($fp);
    echo ftell($fp);
   }
   fclose($fp);
?>


我们在windows下敲下回车键的时候,相当于键入了\n\r,所以“我叫彭湖湾”的15字节+“\n\r”的2字节 = 17字节

在mac下不一样的是:敲下回车键的时候,相当于只键入了\n,所以“我叫彭湖湾”的15字节+“\n”的1字节 = 16字节

相关推荐:

如何将python中文件写入TXT

php使用flock阻塞和非阻塞文件写入的实例讲解

PHP文件读写操作之文件写入代码

php 文件写入

위 내용은 PHP 파일 쓰기 및 그래픽 및 텍스트 세부 정보 읽기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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