用 PHP 读取文件的正确方法
2008-05-16 09:50
731 查看
fopen方法可能是以前的 C 和 C++ 程序员最熟悉的,因为如果您使用过这些语言,那么它们或多或少都是您已掌握多年的工具。对于这些方法中的任何一种,通过使用
fopen(用于读取数据的函数)的标准方法打开文件,然后使用
fclose关闭文件,如清单 1 所示。
清单 1. 用 fgets 打开并读取文件
$file_handle = fopen("myfile", "r"); while (!feof($file_handle)) { $line = fgets($file_handle); echo $line; } fclose($file_handle); |
打开文件。
$file_handle存储了一个对文件本身的引用。
检查您是否已到达文件的末尾。
继续读取文件,直至到达文件末尾,边读取边打印每行。
关闭文件。
记住这些步骤,我将回顾在这里使用的每个文件函数。
fopen
fopen函数将创建与文件的连接。我之所以说“创建连接”,是因为除了打开文件之外,
fopen还可以打开一个 URL:
$fh = fopen("http://127.0.0.1/", "r"); |
注:
fopen中使用的
"r"将指示文件以只读方式打开。由于将数据写入文件不在本文的讨论范围内,因此我将不列出所有其他选项。但是,如果是从二进制文件读取以获得跨平台兼容性,则应当将
"r"更改为
"rb"。稍后您将看到这样的示例。
feof
feof命令将检测您是否已经读到文件的末尾并返回 True 或 False。清单 1 中的循环将继续执行,直至您达到文件“myfile”的末尾。注:如果读取的是 URL 并且套接字由于不再有任何数据可以读取而超时,则
feof也将返回 False。
fclose
向前跳至清单 1 的末尾,
fclose将实现与
fopen相反的功能:它将关闭指向文件或 URL 的连接。执行此函数后,您将不再能够从文件或套接字中读取任何信息。
fgets
在清单 1 中回跳几行,您就到达了文件处理的核心:实际读取文件。
fgets函数是处理第一个示例的首选武器。它将从文件中提取一行数据并将其作为字符串返回。在那之后,您可以打印或者以别的方式处理数据。清单 1 中的示例将精细地打印整个文件。
如果决定限制处理数据块的大小,您可以将一个参数添加到
fgets中限制最大行长度。例如,使用以下代码将行长度限制为 80 个字符:
$string = fgets($file_handle, 81); |
fread
fgets函数是多个文件读取函数中惟一一个可用的。它是一个更常用的函数,因为逐行解析通常会有意义。事实上,几个其他函数也可以提供类似功能。但是,您并非总是需要逐行解析。
这时就需要使用
fread。
fread函数与
fgets的处理目标略有不同:它趋于从二进制文件(即,并非主要包含人类可阅读的文本的文件)中读取信息。由于“行”的概念与二进制文件无关(逻辑数据结构通常都不是由新行终止),因此您必须指定需要读入的字节数。
$fh = fopen("myfile", "rb"); $data = fread($file_handle, 4096); |
|
fread都不会读取超过 8,192 个字节 (8 KB)。
假定文件大小不超过 8 KB,则以下代码应当能将整个文件读入一个字符串。
$fh = fopen("myfile", "rb"); $data = fread($fh, filesize("myfile")); fclose($fh); |
fscanf
回到字符串处理,
fscanf同样遵循传统的 C 文件库函数。如果您不熟悉它,则
fscanf将把字段数据从文件读入变量中。
list ($field1, $field2, $field3) = fscanf($fh, "%s %s %s"); |
fgetss
fgetss函数不同于传统文件函数并使您能更好地了解 PHP 的力量。该函数的功能类似于
fgets函数,但将去掉发现的任何 HTML 或 PHP 标记,只留下纯文本。查看如下所示的 HTML 文件。
清单 2. 样例 HTML 文件
<html> <head><title>My title</title></head> <body> <p>If you understand what "Cause there ain't no one for to give you no pain" means then you listen to too much of the band America</p> </body> </html> |
fgetss函数过滤它。
清单 3. 使用 fgetss
$file_handle = fopen("myfile", "r"); while (!feof($file_handle)) { echo = fgetss($file_handle); } fclose($file_handle); |
My title If you understand what "Cause there ain't no one for to give you no pain" means then you listen to too much of the band America |
无论怎样读取文件,您都可以使用
fpassthru将其余数据转储到标准输出通道。
fpassthru($fh); |
非线性文件处理:跳跃访问
当然,以上函数只允许顺序读取文件。更复杂的文件可能要求您来回跳转到文件的不同部分。这时就用得着
fseek了。
fseek($fh, 0); |
fseek($fh, 1024); |
fseek($fh, 100, SEEK_CUR); |
fseek($fh, -100, SEEK_CUR); |
SEEK_END。
fseek($fh, -100, SEEK_END); |
fgets、
fscanf或任何其他方法读取数据。
注:不能将
fseek用于引用 URL 的文件处理。
|
现在,我们将接触到一些 PHP 的更独特的文件处理功能:用一两行处理大块数据。例如,如何提取文件并在 Web 页面上显示其全部内容?好的,您看到了
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); |
readfile("http://127.0.0.1/"); |
readfile函数将把文件或 Web 页面的全部内容转储到默认的输出缓冲区。默认情况下,如果失败,此命令将打印错误消息。要避免此行为(如果需要),请尝试:
@readfile("http://127.0.0.1/"); |
file_get_contents返回的单个字符串可能有些让人吃不消。您的第一反应可能是用
split()函数将它分解一下。
$array = split("/n", file_get_contents("myfile")); |
file()函数一步即可完成此操作:它将返回分为若干行的字符串数组。
$array = file("myfile"); |
split命令将删除新行,但是当使用
file命令(与
fgets命令一样)时,新行仍将被附加到数组中的字符串上。
但是,PHP 的力量还远不止于此。您可以在一条命令中使用
parse_ini_file解析整个 PHP 样式的 .ini 文件。
parse_ini_file命令接受类似清单 4 所示的文件。
清单 4. 样例 .ini 文件
; Comment [personal information] name = "King Arthur" quest = To seek the holy grail favorite color = Blue [more stuff] Samuel Clemens = Mark Twain Caryn Johnson = Whoopi Goldberg |
$file_array = parse_ini_file("holy_grail.ini"); print_r $file_array; |
Listing 5. 输出
Array ( [name] => King Arthur [quest] => To seek the Holy Grail [favorite color] => Blue [Samuel Clemens] => Mark Twain [Caryn Johnson] => Whoopi Goldberg ) |
parse_ini_file轻松地修正它:
process_sections,这是一个布尔型变量。将
process_sections设为 True。
$file_array = parse_ini_file("holy_grail.ini", true); print_r $file_array; |
清单 6. 输出
Array ( [personal information] => Array ( [name] => King Arthur [quest] => To seek the Holy Grail [favorite color] => Blue ) [more stuff] => Array ( [Samuel Clemens] => Mark Twain [Caryn Johnson] => Whoopi Goldberg ) ) |
对于 PHP 文件处理来说,这只是冰山一角。诸如
tidy_parse_file和
xml_parse之类的更复杂的函数可以分别帮助您处理 HTML 和 XML 文档。有关这些特殊函数的使用细节,请参阅 参考资料。如果您要处理那些类型的文件,则那些参考资料值得一看,但不必过度考虑本文中谈到的每种可能遇到的文件类型,下面是一些用于处理到目前为止介绍的函数的很好的通用规则。
|
绝不要假定程序中的一切都将按计划运行。例如,如果您要查找的文件已被移动该当如何?如果权限已被改变而无法读取其内容又当如何?您可以通过使用
file_exists和
is_readable预先检查这些问题。
清单 7. 使用 file_exists 和 is_readable
$filename = "myfile"; if (file_exists($filename) && is_readable ($filename)) { $fh = fopen($filename, "r"); # Processing fclose($fh); } |
fopen的返回值更简单并且更准确。
if ($fh = fopen($filename, "r")) { # Processing fclose($fh); } |
fopen将返回 False,这将确保仅当文件成功打开后才执行文件处理。当然,如果文件不存在或者不可读,您可以期望一个负返回值。这将使这个检查可以检查所有可能遇到的问题。此外,如果打开失败,可以退出程序或让程序显示错误消息。
如
fopen函数一样,
file_get_contents、
file和
readfile函数都在打开失败或处理文件失败时返回 False。
fgets、
fgetss、
fread、
fscanf和
fclose函数在出错时也返回 False。当然,除
fclose以外,您可能已经对这些函数的返回值都进行了处理。使用
fclose时,即使文件处理未正常关闭,也不会执行什么操作,因此通常不必检查
fclose的返回值。
相关文章推荐
- 用PHP读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用PHP读取文件的正确方法(1)
- 用 PHP 读取文件的正确方法
- PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用 PHP 读取文件的正确方法
- 用PHP读取文件的正确方法(1)
- 用 PHP 读取文件的正确方法
- PHP 读取文件的正确方法
- 用PHP读取文件的正确方法(3)
- 用 PHP 读取文件的正确方法
- 用PHP读取文件的正确方法(4)