| 网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 |
![]() |
| Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道 |
fgetss 网管联盟bitsCN@com
fgetss 函数不同于传统文件函数并使您能更好地了解 PHP 的力量。该函数的功能类似于 fgets 函数,但将去掉发现的任何 HTML 或 PHP 标记,只留下纯文本。查看如下所示的 HTML 文件。 中国网管论坛bbs.bitsCN.com
清单 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);
网管下载dl.bitscn.com |
网管网www.bitscn.com
以下是输出:
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
网管u家u.bitscn@com |
fpassthru 函数
无论怎样读取文件,您都可以使用 fpassthru 将其余数据转储到标准输出通道。 网管下载dl.bitscn.com
fpassthru($fh); |
此外,此函数将打印数据,因此无需使用变量获取数据。 网管联盟bitsCN_com
非线性文件处理:跳跃访问 中国网管联盟bitsCN.com
当然,以上函数只允许顺序读取文件。更复杂的文件可能要求您来回跳转到文件的不同部分。这时就用得着 fseek 了。
网管联盟bitsCN_com
fseek($fh, 0);
网管u家u.bitscn@com |
以上示例将跳转回文件的开头。如果不需要完全返回 —— 我们可设定返回千字节 —— 然后就可以这样写:
fseek($fh, 1024); |
从 PHP V4.0 开始,您有一些其他选项。例如,如果需要从当前位置向前跳转 100 个字节,则可以尝试使用:
网管网www.bitscn.com
fseek($fh, 100, SEEK_CUR); |
类似地,可以使用以下代码向后跳转 100 个字节: 网管下载dl.bitscn.com
fseek($fh, -100, SEEK_CUR); |
如果需要向后跳转至文件末尾前 100 个字节处,则应使用 SEEK_END。
fseek($fh, -100, SEEK_END); 网管网www_bitscn_com |
在到达新位置后,可以使用 fgets、fscanf 或任何其他方法读取数据。
网管网www_bitscn_com
注:不能将 fseek 用于引用 URL 的文件处理。
中国网管联盟bitsCN.com
提取整个文件 网管网www_bitscn_com
现在,我们将接触到一些 PHP 的更独特的文件处理功能:用一两行处理大块数据。例如,如何提取文件并在 Web 页面上显示其全部内容?好的,您看到了 fgets 使用循环的示例。但是如何能够使此过程变得更简单?用 fgetcontents 会使过程超级简单,该方法将把整个文件放入一个字符串中。
$my_file = file_get_contents("myfilename");
echo $my_file;
|
网管u家u.bitscn@com
虽然它不是最好的做法,但是可以将此命令更简明地写为: 网管论坛bbs_bitsCN_com
echo file_get_contents("myfilename");
|
本文主要介绍的是如何处理本地文件,但是值得注意的是您还可以用这些函数提取、回显和解析其他 Web 页面。 网管论坛bbs_bitsCN_com
echo file_get_contents("http://127.0.0.1/");
网管u家u.bitscn@com |
中国网管联盟bitsCN.com
此命令等效于: 网管u家u.bitsCN.com
$fh = fopen("http://127.0.0.1/", "r");
fpassthru($fh);
|
您一定会查看此命令并认为:“那还是太费力”。PHP 开发人员同意您的看法。因此可以将以上命令缩短为: 网管u家u.bitsCN.com
readfile("http://127.0.0.1/");
中国网管联盟bitsCN.com |
readfile 函数将把文件或 Web 页面的全部内容转储到默认的输出缓冲区。默认情况下,如果失败,此命令将打印错误消息。要避免此行为(如果需要),请尝试: 网管u家u.bitsCN.com
@readfile("http://127.0.0.1/");
|
当然,如果确实需要解析文件,则 file_get_contents 返回的单个字符串可能有些让人吃不消。您的第一反应可能是用 split() 函数将它分解一下。
网管u家u.bitscn@com
$array = split("\n", file_get_contents("myfile"));
|
网管u家u.bitscn@com
但是既然已经有一个很好的函数为您执行此操作为什么还要这样大费周章?PHP 的 file() 函数一步即可完成此操作:它将返回分为若干行的字符串数组。
$array = file("myfile");
网管联盟bitsCN_com |
应当注意的是,以上两个示例有一点细微差别。虽然 split 命令将删除新行,但是当使用 file 命令(与 fgets 命令一样)时,新行仍将被附加到数组中的字符串上。 网管联盟bitsCN@com
但是,PHP 的力量还远不止于此。您可以在一条命令中使用 parse_ini_file 解析整个 PHP 样式的 .ini 文件。parse_ini_file 命令接受类似清单 4 所示的文件。 网管下载dl.bitscn.com
|
0
|
评论加载中…