读
fopen
# 文件指针名=fopen(文件名,使用文件方式)
"r" 打开文字文件只读
"w" 创建文字文件只写
"a" 增补, 如果文件不存在则创建一个
"r+" 打开一个文字文件读/写
"w+" 创建一个文字文件读/写
"a+" 打开或创建一个文件增补
"b" 二进制文件(可以和上面每一项合用)
"t" 文本文件(默认项)
===========================================================
"rt" 只读打开一个文本文件,只允许读数据
"wt" 只写打开或建立一个文本文件,只允许写数据
"at" 追加打开一个文本文件,并在文件末尾写数据
"rb" 只读打开一个二进制文件,只允许读数据
"wb" 只写打开或建立一个二进制文件,只允许写数据
"ab" 追加打开一个二进制文件,并在文件末尾写数据
"rt+" 读写打开一个文本文件,允许读和写
"wt+" 读写打开或建立一个文本文件,允许读写
"at+" 读写打开一个文本文件,允许读,或在文件末追加数 据
"rb+" 读写打开一个二进制文件,允许读和写
"wb+" 读写打开或建立一个二进制文件,允许读和写
"ab+" 读写打开一个二进制文件,允许读,或在文件末追加数据
===========================================================
r(read) 读
w(write) 写
a(append) 追加
t(text) 文本文件,可省略不写
b(banary) 二进制文件
+ 读和写
把一个文本文件读入内存时,要将ASCII码转换成二进制码, 而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。
fread
| # string fread ( int $handle , int $length ) # fread() 从 handle 指向的文件中读取最多 length 个字节。 # 该函数在读取完最多 length 个字节数,或到达 EOF 的时候,或(对于网络流)当一个包可用时,或(在打开用户空间流之后)已读取了 8192 个字节时就会停止读取文件,视乎先碰到哪种情况。 $filename = "./file.txt"; $handle = fopen($filename, "r"); // 读取二进制文件时。需要将第二个参数设置成 'rb' $contents = fread($handle, filesize($filename)); fclose($handle); # 如果所要读取的文件不是本地普通文件,而是远程文件或者流文件,就不能用这种方法,因为,filesize不能获得这些文件的大小。此时,你需要通过feof()或者fread()的返回值判断是否已经读取到了文件的末尾。 $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(!feof($handle)){ $content .= fread($handle, 1024); } fclose($handle); |
fgets
| string fgets ( int $handle [, int $length ] ) |
| |
| |
| |
| |
| $handle = fopen('./file.txt', 'r'); |
| while(!feof($handle)){ |
| echo fgets($handle, 1024); |
| } |
| fclose($handle); |
| |
| |
| |
| |
| |
fgetss [废弃]
| # string fgetss ( resource $handle [, int $length [, string $allowable_tags ]] ) # 跟fgets功能一样,但是fgetss会尝试从读取的文本中去掉任何 HTML 和 PHP 标记,可以用可选的第三个参数指定哪些标记不被去掉。 $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgetss($handle, 1024, '<br>'); } fclose($handle); # 警告:从PHP 7.3.0开始,此函数已被弃用,并从PHP 8.0.0开始删除。 |
file
| # array file ( string $filename [, int $use_include_path [, resource $context ]] )
|
readfile
| # int readfile ( string $filename [, bool $use_include_path [, resource $context ]] ) # 读入一个文件并写入到输出缓冲。返回从文件中读入的字节数。 # 如果出错返回 FALSE 并且除非是以 @readfile() 形式调用,否则会显示错误信息。 $size = readfile('./file.txt'); echo $size; |
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貌似比file_get_contents性能好一点,因为它不需要调用fopen。 echo file_get_contents("http://www.baidu.com/", 0, stream_context_create([ 'http' => [ 'timeout' => 0.1,
|
fpassthru
| # int fpassthru ( resource $handle ) # 将给定的文件指针从当前的位置读取到 EOF 并把结果写到输出缓冲区。 header("Content-Type:text/html;charset=utf-8"); $handle = fopen('./test.php', 'r'); fseek($handle, 128);
|
- 鼓励在处理二进制文件时使用 b 标志,即使系统并不需要,这样可以使脚本的移植性更好。
- allow_url_fopen选项激活了 URL 形式的 fopen 封装协议使得可以访问 URL 对象例如文件。默认的封装协议提供用 ftp 和 http 协议来访问远程文件,一些扩展库例如 zlib 可能会注册更多的封装协议。出于安全性考虑,此选项只能在 php.ini 中设置。
- 如果要打开有特殊字符的 URL (比如说有空格),就需要使用 urlencode() 进行 URL 编码。
写
fwrite
| $fileStream = fopen(filePath,"w"); 给文件末尾追加内容用a+ fwrite($fileStream,"要写入的内容"); 返回写入的字符数,出现错误时则返回 FALSE 。 |
file_put_contents
| file_put_contents($filePath, "要写入的内容", FILE_APPEND); # FILE_USE_INCLUDE_PATH 在 include 目录里搜索 filename。 更多信息可参见 include_path。 # FILE_APPEND 如果文件 filename 已经存在,追加数据而不是覆盖。。 # LOCK_EX 在写入时获得一个独占锁。 # 要写入的数据。类型可以是 string,array 或者是 stream 资源 # 内部会自动关闭文件流,FILE_APPEND以追加方式添加,如果没有则默认是对内容清空再写入 。 # 和依次调用 fopen(),fwrite() 以及 fclose() 功能一样。 |
fputs
| $file = fopen("./test", "w"); echo fputs($file, "Hello World!"); // 返回写入的字节数 fclose($file); |
删除
参考:
https://blog.csdn.net/qq_36207266/article/details/80922993
文件锁
参考:https://blog.csdn.net/jquery_zhang/article/details/50328169
| // LOCK_EX 排他锁 Exclusive lock |
| // LOCK_SH 共享锁 Shared lock |
| // LOCK_UN 释放锁 Release lock |
| // LOCK_NB 阻塞 Non-blocking |
文件无法打开,查看错误原因
| set_error_handler(function ($errno, $errstr){ dd("<b>Error:</b> [$errno] $errstr"); }); $f = fopen( __DIR__ . "/log.txt", "a+"); if(flock($f, LOCK_EX)){ fwrite($f, "hello" . "\n"); flock($f, LOCK_UN); } fclose($f); |