Sophie

Sophie

distrib > Mandriva > 2008.1 > x86_64 > by-pkgid > 05cd670d8a02b2b4a0ffb1756f2e8308 > files > 1025

php-manual-zh-5.2.4-1mdv2008.1.noarch.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML
><HEAD
><TITLE
>fgetcsv</TITLE
><META
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK
REL="HOME"
TITLE="PHP 手册"
HREF="index.html"><LINK
REL="UP"
TITLE="Filesystem 文件系统函数"
HREF="ref.filesystem.html"><LINK
REL="PREVIOUS"
TITLE="fgetc"
HREF="function.fgetc.html"><LINK
REL="NEXT"
TITLE="fgets"
HREF="function.fgets.html"><META
HTTP-EQUIV="Content-type"
CONTENT="text/html; charset=UTF-8"></HEAD
><BODY
CLASS="refentry"
BGCOLOR="#FFFFFF"
TEXT="#000000"
LINK="#0000FF"
VLINK="#840084"
ALINK="#0000FF"
><DIV
CLASS="NAVHEADER"
><TABLE
SUMMARY="Header navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TH
COLSPAN="3"
ALIGN="center"
>PHP 手册</TH
></TR
><TR
><TD
WIDTH="10%"
ALIGN="left"
VALIGN="bottom"
><A
HREF="function.fgetc.html"
ACCESSKEY="P"
>上一页</A
></TD
><TD
WIDTH="80%"
ALIGN="center"
VALIGN="bottom"
></TD
><TD
WIDTH="10%"
ALIGN="right"
VALIGN="bottom"
><A
HREF="function.fgets.html"
ACCESSKEY="N"
>下一页</A
></TD
></TR
></TABLE
><HR
ALIGN="LEFT"
WIDTH="100%"></DIV
><H1
><A
NAME="function.fgetcsv"
></A
>fgetcsv</H1
><DIV
CLASS="refnamediv"
><A
NAME="AEN52442"
></A
><P
>    (PHP 3 &#62;= 3.0.8, PHP 4, PHP 5)</P
>fgetcsv&nbsp;--&nbsp;从文件指针中读入一行并解析 CSV 字段</DIV
><DIV
CLASS="refsect1"
><A
NAME="AEN52445"
></A
><H2
>说明</H2
>array <B
CLASS="methodname"
>fgetcsv</B
> ( int handle [, int length [, string delimiter [, string enclosure]]] )<BR
></BR
><P
>&#13;   <P
></P
><DIV
CLASS="variablelist"
><DL
><DT
><CODE
CLASS="parameter"
>handle</CODE
></DT
><DD
><P
>&#13;       一个由 <A
HREF="function.fopen.html"
><B
CLASS="function"
>fopen()</B
></A
>、<A
HREF="function.popen.html"
><B
CLASS="function"
>popen()</B
></A
> 或
       <A
HREF="function.fsockopen.html"
><B
CLASS="function"
>fsockopen()</B
></A
> 产生的有效文件指针。
      </P
></DD
><DT
><CODE
CLASS="parameter"
>length</CODE
> (可选)</DT
><DD
><P
>&#13;       必须大于 CVS 文件内最长的一行。在 PHP 5
       中该参数是可选的。如果忽略(在 PHP 5.0.4 以后的版本中设为
       0)该参数的话,那么长度就没有限制,不过可能会影响执行效率。
      </P
></DD
><DT
><CODE
CLASS="parameter"
>delimiter</CODE
> (可选)</DT
><DD
><P
>&#13;       设置字段分界符(只允许一个字符),默认值为逗号。
      </P
></DD
><DT
><CODE
CLASS="parameter"
>enclosure</CODE
> (可选)</DT
><DD
><P
>&#13;       设置字段环绕符(只允许一个字符),默认值为双引号。该参数是在 PHP 4.3.0 中添加的。
      </P
></DD
></DL
></DIV
>
  </P
><P
>&#13;   和 <A
HREF="function.fgets.html"
><B
CLASS="function"
>fgets()</B
></A
> 类似,只除了
   <B
CLASS="function"
>fgetcsv()</B
> 解析读入的行并找出 <ACRONYM
CLASS="acronym"
>CSV</ACRONYM
>
   格式的字段然后返回一个包含这些字段的数组。
  </P
><P
>&#13;   <B
CLASS="function"
>fgetcsv()</B
> 出错时返回 <TT
CLASS="constant"
><B
>FALSE</B
></TT
>,包括碰到文件结束时。
  </P
><DIV
CLASS="note"
><BLOCKQUOTE
CLASS="note"
><P
><B
>注意: </B
>
    CSV 文件中的空行将被返回为一个包含有单个 <A
HREF="language.types.null.html"
><B
CLASS="type"
>null</B
></A
> 字段的数组,不会被当成错误。
   </P
></BLOCKQUOTE
></DIV
><P
>&#13;   <TABLE
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
CLASS="EXAMPLE"
><TR
><TD
><DIV
CLASS="example"
><A
NAME="AEN52498"
></A
><P
><B
>例 1. 读取并显示 CSV 文件的整个内容</B
></P
><TABLE
BORDER="0"
BGCOLOR="#E0E0E0"
CELLPADDING="5"
><TR
><TD
><code><font color="#000000">
<font color="#0000BB">&lt;?php<br />$row </font><font color="#007700">= </font><font color="#0000BB">1</font><font color="#007700">;<br /></font><font color="#0000BB">$handle </font><font color="#007700">= </font><font color="#0000BB">fopen</font><font color="#007700">(</font><font color="#DD0000">"test.csv"</font><font color="#007700">,</font><font color="#DD0000">"r"</font><font color="#007700">);<br />while (</font><font color="#0000BB">$data </font><font color="#007700">= </font><font color="#0000BB">fgetcsv</font><font color="#007700">(</font><font color="#0000BB">$handle</font><font color="#007700">, </font><font color="#0000BB">1000</font><font color="#007700">, </font><font color="#DD0000">","</font><font color="#007700">)) {<br />&nbsp;&nbsp;&nbsp;&nbsp;</font><font color="#0000BB">$num </font><font color="#007700">= </font><font color="#0000BB">count</font><font color="#007700">(</font><font color="#0000BB">$data</font><font color="#007700">);<br />&nbsp;&nbsp;&nbsp;&nbsp;echo </font><font color="#DD0000">"&lt;p&gt; $num fields in line $row: &lt;br&gt;</font><font color="#007700">\n</font><font color="#DD0000">"</font><font color="#007700">;<br />&nbsp;&nbsp;&nbsp;&nbsp;</font><font color="#0000BB">$row</font><font color="#007700">++;<br />&nbsp;&nbsp;&nbsp;&nbsp;for (</font><font color="#0000BB">$c</font><font color="#007700">=</font><font color="#0000BB">0</font><font color="#007700">; </font><font color="#0000BB">$c </font><font color="#007700">&lt; </font><font color="#0000BB">$num</font><font color="#007700">; </font><font color="#0000BB">$c</font><font color="#007700">++) {<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;echo </font><font color="#0000BB">$data</font><font color="#007700">[</font><font color="#0000BB">$c</font><font color="#007700">] . </font><font color="#DD0000">"&lt;br&gt;\n"</font><font color="#007700">;<br />&nbsp;&nbsp;&nbsp;&nbsp;}<br />}<br /></font><font color="#0000BB">fclose</font><font color="#007700">(</font><font color="#0000BB">$handle</font><font color="#007700">);<br /></font><font color="#0000BB">?&gt;</font>
</font>
</code></TD
></TR
></TABLE
></DIV
></TD
></TR
></TABLE
>
  </P
><P
>&#13;   从 PHP 4.3.5 起,<B
CLASS="function"
>fgetcsv()</B
> 的操作是二进制安全的。
  </P
><DIV
CLASS="note"
><BLOCKQUOTE
CLASS="note"
><P
><B
>注意: </B
>
    该函数对区域设置是敏感的。比如说 <CODE
CLASS="varname"
>LANG</CODE
> 设为
    <TT
CLASS="literal"
>en_US.UTF-8</TT
> 的话,单字节编码的文件就会出现读取错误。
   </P
></BLOCKQUOTE
></DIV
><DIV
CLASS="note"
><BLOCKQUOTE
CLASS="note"
><P
><B
>注意: </B
>如果碰到 <TT
CLASS="literal"
>PHP</TT
>
在读取文件时不能识别 Macintosh 文件的行结束符,可以激活
<A
HREF="ref.filesystem.html#ini.auto-detect-line-endings"
>auto_detect_line_endings</A
>
运行时配置选项。</P
></BLOCKQUOTE
></DIV
><P
>&#13;   参见 <A
HREF="function.explode.html"
><B
CLASS="function"
>explode()</B
></A
>,<A
HREF="function.file.html"
><B
CLASS="function"
>file()</B
></A
>,<A
HREF="function.pack.html"
><B
CLASS="function"
>pack()</B
></A
>
   和 <A
HREF="function.fputcsv.html"
><B
CLASS="function"
>fputcsv()</B
></A
>
  </P
></DIV
><DIV
CLASS="NAVFOOTER"
><HR
ALIGN="LEFT"
WIDTH="100%"><TABLE
SUMMARY="Footer navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
><A
HREF="function.fgetc.html"
ACCESSKEY="P"
>上一页</A
></TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="index.html"
ACCESSKEY="H"
>起始页</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
><A
HREF="function.fgets.html"
ACCESSKEY="N"
>下一页</A
></TD
></TR
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
>fgetc</TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="ref.filesystem.html"
ACCESSKEY="U"
>上一级</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
>fgets</TD
></TR
></TABLE
></DIV
></BODY
></HTML
>