PHP文件操作
像其他编程语言(c , java)一样,php内置了多个文件函数,用来完成文件的打开、读写、关闭等操作。
1.打开文件
resource fopen(string $filename,string mode,[,bool $use_include_path=false[,resource context]] )
fopen函数用于打开一个已存在的文件,如果文件不存在或打开失败,返回false,可以在前面加@来屏蔽这个错误;如果正确打开,返回文件指针句柄。
fopen支持多种模式:
模式 | 模式名称 | 意义 |
---|---|---|
r | 只读 | 打开文件,从文件头开始读 |
r+ | 读写 | 打开文件,从文件头开始读写 |
w | 只写 | 打开文件,从文件头开始写,若文件存在会删除原有内容,若文件不存在,会创建这个文件 |
w+ | 读写 | 打开文件,从文件头开始读写,若文件存在会删除原有内容,若文件不存在,会创建这个文件 |
x | 谨慎写 | 打开文件,从文件头开始写,若文件存在,返回false,若文件不存在,会创建这个文件 |
x+ | 谨慎读写 | 打开文件,从文件头开始读写,若文件存在,返回false,若文件不存在,会创建这个文件 |
a | 追加写 | 打开文件,如果文件已有内容,在文件尾追加写,若文件不存在,会创建这个文件 |
a+ | 追加读写 | 打开文件,如果文件已有内容,在文件尾追加读写,若文件不存在,会创建这个文件 |
b | 二进制 | 二进制模式,用于和其它模式连接。windows区分二进制文件和文本文件,而Unix不区分,推荐使用这个选项达到兼容性 |
t | 文本 | 文本模式,用于和其它模式连接,只是windows系统下的一个选项 |
2.写文件
php中写文件函数为fwrite(),同样可以用fputs()函数,它是fwrite的别名函数。
int fwrite($fp, $outputstring,[,int length])
$fp是fopen函数返回的文件句柄,$outputstring是要写入文件的字符串。length是写入的长度。写入成功返回写入的字节数,失败返回false。
此外,可以使用file_put_contents函数来写文件,它的效果和依次调用fopen,fwrite,fclose的效果一样,也就是说不需要调用fopen函数就可以写入数据到文件。
int file_put_contens(string filename,string data,[,int flags[,resource context]])
该函数返回写入文件的字节数,失败返回false。
3.读文件
读文件有多种方式,根据需求可能按行读取,可能按字节读取,也可能整个文件读取。按行读取和按字节读取需要用feof函数检测文件末尾。
bool feof(resource $handle)
$handle是fopen函数返回的句柄,若文件达到末尾EOF(end of file)或出错返回true,否则返回false。
-
每次读取一行数据
读取一行数据可以用fgets、fgetss、fgetcsv函数。
string fgets(resource $handle, [,int length])
$handle是fopen函数返回的句柄,length默认长度为1024字节,如果指定了length参数,那么每行最多读取并返回length个字节。
string fgetss(resource $handle,[,int length[,string $allowable_tags]])
和fgets相似,只是fgetss会去掉任何HTML和PHP标记。$handle是fopen函数返回的句柄,length指定每行的字节数,$allowable_tags指定哪些标记不被去掉。
array fgetcsv(resource $handle,[,int length=0[,string delimiter=','[,string enclosure='"'[,string escape='\\']]]])
和fgets类似,只是除了读出的每一行并找出 CSV格式的字段然后返回一个包含这些字段的数组。
-
每次读取一个字符
读取一个字符使用fgetc函数实现。
string fgetc(resource $handle)
$handle是fopen函数返回的句柄。fgetc会返回文件结束符EOF,而fgets不会,因此读取字符时需要判断是不是EOF,一般情况下不希望显示EOF。
-
读取整个文件
读取整个文件可以用readfile、fpassthru、file函数。
int readfile(string $filename,[,bool $use_include_path=false[,resource $context]])
调用readfile会打开文件,并将文件内容输出到标准输出(浏览器)中,然后关闭这个文件。读取成功返回读入的文件字节数,失败返回false。
int fpassthru(resource $handle)
这和readfile类似,只是需要先调用fopen函数打开,然后将文件句柄传入这个函数,结果将文件内容输出到标准输出,最后关闭文件。
array file(string $filename,[,int flags=0[,resource $context]])
file函数除了可以将文件内容回显到标准输出外,它将文件的每一行返回到一个数组中。
string file_get_contents(string $filename,[,bool $use_include_path=false[,resource $context[,int $offset=-1[,int $maxlen]]]])
和file_put_contents相反,file_get_contents将整个文件内容读入到一个字符串中,并且不会将文件内容输出到标准输出中。
-
读取任意长度
可以使用fread函数从文件中读取任意长度的字节。
string fread(resource $handle, int length)
成功返回读取的字符串,失败返回false。
4.关闭文件
当用fopen打开一个文件,使用完这个文件之后(读写)需要将其关闭,关闭一个文件调用fclose函数实现。
bool fclose(resource $handle)
若文件成功关闭返回true,反之返回false。
5.文件锁定
为了避免多个用户同时读写一个文件,引起资源竞争导致不可预知的结果,往往需要在打开一个文件后给它加锁。文件锁定使用flock函数实现
bool flock(resource $handle,int $operation [,int &$wouldblock])
文件加锁操作默认是阻塞模式,可以设置模式为LOCK_NB来取消阻塞。支持的模式包括如下:
模式 | 意义 |
---|---|
LOCK_SH | 读操作锁定,文件共享,其他人可以读该文件 |
LOCK_EX | 写操作锁定,文件互斥,该文件不能共享 |
LOCK_UN | 释放已有的锁定 |
LOCK_NB | 防止在请求加锁时发生阻塞 |
6.其他文件相关函数
-
file_exists
在不打开文件的前提下,使用file_exists函数检查这个文件是否存在,它也可以检查一个目录是否存在。
bool file_exists(string $filename)
-
filesize
使用filesize函数来检测一个文件的大小。
int filesize(string $filename)
-
unlink
使用unlink删除一个文件
bool unlink(string $filename,[,resource $context])
-
rewind fseek ftell
这三个是文件定位函数,可以对文件指针进行操作。rewind函数在文件指针复位到文件开始,ftell函数返回当前文件指针所在的字节数位置,fseek用于将文件指针指向文件的某个位置。
bool rewind(resource $handle, int $offset,[,int $whence=SEEK_SET] )
int fseek()
int ftell(resource $handle)