时间:2021-07-01 10:21:17 帮助过:28人阅读
csv,是一种特殊格式的表单文本文件,用‘,’分隔每个字段,用’\n’分隔每行。可以用fgetcsv读取每个字段,或者用fgets读取每行,然后用explode(‘,’,$data)分隔每行的数据。
fgetcsv ? 从文件指针中读入一行并解析 CSV 字段
array fgetcsv ( resource $handle [, int $length = 0 [, string $delimiter = ‘,’ [, string $enclosure = ‘”’ [, string $escape = ‘\’ ]]]] )
handle
接受一个由 fopen()、 popen() 或 fsockopen() 产生的有效文件指针。
length
必须大于 CVS 文件内最长的一行。在 PHP 5 中该参数是可选的。如果忽略(在 PHP 5.0.4 以后的版本中设为 0)该参数的话,那么长度就没有限制,不过可能会影响执行效率。
delimiter
设置字段分界符(只允许一个字符)。
enclosure
设置字段环绕符(只允许一个字符)。
escape
设置转义字符(只允许一个字符),默认是一个反斜杠。
注意:如果csv字段的字符长度大于设置的length,那么函数每次只会读取length长度的字符,并返回索引为0的数组,当遇到分隔符’,’时,分隔符后的字符串会被屏蔽。
example
\n"; } fclose($handle);}?>
以上会输出
user11
11
r222
user33
33
r4444
fgets ? 从文件指针中读取一行
string fgets ( resource $handle [, int $length ] )
handle
文件指针必须是有效的,必须指向由 fopen() 或 fsockopen() 成功打开的文件(并还未由 fclose() 关闭)。
length
从 handle 指向的文件中读取一行并返回长度最多为 length - 1 字节的字符串。碰到换行符(包括在返回值中)、EOF 或者已经读取了 length - 1 字节后停止(看先碰到那一种情况)。如果没有指定 length,则默认为 1K,或者说 1024 字节。
Note:
从 PHP 4.3 开始,忽略掉 length 则行的长度被假定为 1024,将继续从流中读取数据直到行结束。如果文件中的大多数行都大于 8KB,则在脚本中指定最大行的长度在利用资源上更为有效。
从指针 handle 指向的文件中读取了 length - 1 字节后返回字符串。 如果文件指针中没有更多的数据了则返回 FALSE。
错误发生时返回 FALSE。