In diesem Artikel werden hauptsächlich die Details zum Schreiben und Lesen von Grafiken und Texten in PHP-Dateien vorgestellt. Ich hoffe, dass er für alle hilfreich ist. Artikelübersicht:
1. Grundlegende Ideen zum Realisieren des Lesens und Schreibens von Dateien
2. Verwenden Sie die fopen-Methode, um die Datei zu öffnen
3. Vorgänge zum Lesen und Schreiben von Dateien
4. Verwenden Sie die fclose-Methode, um die Datei zu schließen
5. Bewegung des Dateizeigers
6. Wagenrücklauf und Zeilenvorschub unter Windows und UNIX
1. Die Grundidee der Implementierung des Lesens und Schreibens von Dateien:
1. Öffnen Sie die Datei mit der fopen-Methode: $fp =fopen(/*parameter, Parameter*/), fp ist Ressourcentyp
2. Führen Sie Dateilese- oder Dateischreibvorgänge durch (die hier verwendete Funktion verwendet das in 1 zurückgegebene $fp als Parameter)
3. Rufen Sie fclose($fp) auf, um die Datei zu schließen
Zwei: Verwenden Sie die fopen-Methode, um die Datei zu öffnen
fopen (Dateipfad [Zeichenfolge], Öffnungsmodus [Zeichenfolge])
<1> erster von fopen Der erste Parameter ist der Dateipfad
Die Art und Weise, den Dateipfad zu schreiben: 1 absoluter Pfad, 2 relativer Pfad
1 absoluter Pfad :
Freunde, die unter Windows arbeiten, sollten damit vertraut sein. Das Pfadtrennzeichen unter Windows ist „“ anstelle von „/“, aber wir können nicht das offizielle „“ als Trennzeichen verwenden Den Pfad schreiben
Was passiert, wenn wir den Pfad mit dem Trennzeichen „“ schreiben?
<?php $fp = fopen("C:\wamp64\www\text.txt",'w'); ?>
Nach der Ausführung wird ein Fehler gemeldet, der darauf hinweist, dass der Pfadparameter ungültig ist
Also müssen wir das Trennzeichen „“ durch „/“ ersetzen:
<?php $fp = fopen("C:/wamp64/www/text.txt",'w'); ?>
Beim Ausführen wird kein Fehler gemeldet, was darauf hinweist, dass die Parameter gültig sind.
[Hinweis]Die fopen-Funktion kann das Trennzeichen „“ nicht verstehen. Wenn Sie „“ verwenden möchten, müssen Sie Escape verwenden, z. B. Schreiben : „C:\wamp64\www\text.txt“ ist ebenfalls möglich und die Funktion kann es verstehen, ohne einen Fehler zu melden. Dennoch wird die Verwendung von „“ nicht empfohlen, da unter OS (Mac) nur „/“ erkannt werden kann, nicht jedoch „“
Fazit von Dieser Abschnitt: Es wird empfohlen, bei der Verwendung von „/“ als Trennzeichen zu bleiben
2. Relativer Pfad:
Zurück In diesem Abschnitt wird erläutert, wie absolute Pfade geschrieben werden. Dies bringt jedoch ein weiteres Problem mit sich: Die Verzeichnisstruktur des Servers kann sich erheblich ändern, und dann werden alle ursprünglichen absoluten Pfade neu geschrieben. Beispielsweise auf meinem Computer Die Zieldatei Der Pfad lautet C:/wamp64/www/text.txt. Was passiert, wenn ich den www-Ordner in penghuwan umbenenne? Die ursprünglich geschriebenen Pfadparameter sind ungültig. Deshalb haben wir die Methode zum Schreiben relativer Pfade eingeführt:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w'); ?>
• $_SERVER ist eine super globale Variable von PHP (überall im Code verfügbar). Zugriff, der Typ ist ein Array), das Standard-Stammverzeichnis des Servers kann über $_SERVER['DOCUMENT_ROOT'] abgerufen werden
Das Standard-Stammverzeichnis des Servers kann über php.ini geändert werden (dies kann sei selbst Baidu)
• $_SERVER['DOCUMENT_ROOT'] entspricht hier C:/wamp64/www
Fazit dieses Abschnitts: Das ist es Es wird empfohlen, relative Pfade zu verwenden
<2>Der zweite Parameter von fopen ist der Öffnungsmodus
Nach dem Festlegen des Öffnungsmodus entsprechen wir der Einstellung Berechtigungen für die nachfolgenden Lese- und Schreibvorgänge:
Die grundlegendsten Modi:
"r": Dateien können nur gelesen werden, aber Dateien kann nicht geschrieben werden (Schreibvorgänge werden ignoriert)
„w“: Kann nur Dateien schreiben, keine Dateien lesen (Lesevorgänge werden ignoriert)
„a“: Nur Dateien anhängen, ähnlich wie „w“, der Unterschied ist dass „w“ den ursprünglichen Inhalt löscht, „a“ den ursprünglichen Inhalt nicht löscht, sondern nur den Inhalt anhängt
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w'); fwrite($fp,'在写模式下写入'); fclose($fp); ?>
Danach Wenn Sie die Berechtigung für den Schreibvorgang festlegen, kann er normal funktionieren. Die Datei wird in die Datei geschrieben
Öffnen Sie nach dem Ausführen C:/wamp64/www/text.txt:
Dieses Mal stellen wir die Berechtigung auf schreibgeschützt und versuchen, Text zu schreiben: „Im schreibgeschützten Modus schreiben“
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); fwrite($fp,'在读模式下写入'); fclose($fp); ?>
Nach dem Ausführen von open C:/wamp64/www/text.txt wurde festgestellt, dass sich der Dateiinhalt nicht geändert hat, was darauf hinweist, dass der Vorgang ignoriert wurde, da die entsprechenden Berechtigungen nicht festgelegt wurden
关于打开模式的网络资料,我想大家最可能找到的是这张表:(图来自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['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r+'); fwrite($fp,'r+ mode'); fclose($fp); ?>
运行后再打开文本,发现“I am in”被“r+ mode”覆盖了:
• 采用a+模式写入文本“a+ mode”
基于”I am initialized value”的初始文本我们运行以下代码:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'a+'); fwrite($fp,'a+ mode'); fclose($fp); ?>
I am initialized value没有被删除和覆盖,而是在后面追加了a+ mode的这一段新文本
运行多次后:
•采用w+模式写入文本“w+ mode”
基于”I am initialized value”的初始文本我们运行以下代码:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w+'); fwrite($fp,'w+ mode'); 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['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r');//打开文件 if(file_exists("$DOCUMENT_ROOT/text.txt")){//当文件存在时,才读取内容 while(!feof($fp)){//判断文件指针是否到达末尾 $c = fgetc($fp);//每执行一次fgetc(),文件指针就向后移动一位 echo $c;//输出获取到的字节 } } fclose($fp);//关闭文件 ?>
运行:
【注意】:无论是按文本格式输入输出还是按二进制格式输出,fgetc()每次获取的是一个字节而不是一个字符!
上面的例子中我们是逐个输出,现在让我们只做一次输出,看看结果怎样:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fgetc($fp);//只做一次输出 close($fp); ?>
运行结果如下,我们得到的不是汉字“我”,而是一个乱码,其实这个乱码就是一个字节
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fgetc($fp);//连续做三次输出 echo fgetc($fp); echo fgetc($fp); fclose($fp); ?>
2.一次读取多个字节 ——通过fread()方法:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fread($fp, 3);//一次输出三个字节即一个汉字字符(UTF-8) fclose($fp); ?>
运行结果:
改成:
echo fread($fp, 6);
运行结果如下,输出了6个字节也即两个汉字字符(UTF-8)
3.一次读取一行——通过fgets()获取一行内容
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT'] $fp = fopen("$DOCUMENT_ROOT/text.txt",'r');//打开文件 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['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); fpassthru($fp); fclose($fp); ?>
运行结果:
【注意】这里需要注意一点的是,我们并没有从fpassthru($fp)获取到返回值然后echo到页面上去,也就是说这个方法是会强制输出获取的内容的,而并不是像之前例子的方法那样返回文本,允许我们保存到变量中才将其输出
将读取到的全部内容保存到一个数组中,每个数组元素为一行的内容——fille()
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $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['DOCUMENT_ROOT']; function print_file_pointer($fp){//定义一个打印文件指针位置的函数 echo " <br/>//此时文件指针的位置:"; echo ftell($fp)."<br/>"; } $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); 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['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); 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字节
相关推荐:
Das obige ist der detaillierte Inhalt vonSchreiben und Lesen von Grafiken und Textdetails in PHP-Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!