<?xml version="1.0" encoding="utf-8"?> <!-- $Revision$ --> <refentry xmlns="http://docbook.org/ns/docbook" xml:id="function.file"> <refnamediv> <refname>file</refname> <refpurpose>Reads entire file into an array</refpurpose> </refnamediv> <refsect1 role="description"> &reftitle.description; <methodsynopsis> <type>array</type><methodname>file</methodname> <methodparam><type>string</type><parameter>filename</parameter></methodparam> <methodparam choice="opt"><type>int</type><parameter>flags</parameter><initializer>0</initializer></methodparam> <methodparam choice="opt"><type>resource</type><parameter>context</parameter></methodparam> </methodsynopsis> <para> Reads an entire file into an array. </para> <note> <para> You can use <function>file_get_contents</function> to return the contents of a file as a string. </para> </note> </refsect1> <refsect1 role="parameters"> &reftitle.parameters; <para> <variablelist> <varlistentry> <term><parameter>filename</parameter></term> <listitem> <para> Path to the file. </para> &tip.fopen-wrapper; </listitem> </varlistentry> <varlistentry> <term><parameter>flags</parameter></term> <listitem> <para> The optional parameter <parameter>flags</parameter> can be one, or more, of the following constants: <variablelist> <varlistentry> <term> <constant>FILE_USE_INCLUDE_PATH</constant> </term> <listitem> <simpara> Search for the file in the <link linkend="ini.include-path">include_path</link>. </simpara> </listitem> </varlistentry> <varlistentry> <term> <constant>FILE_IGNORE_NEW_LINES</constant> </term> <listitem> <simpara> Omit newline at the end of each array element </simpara> </listitem> </varlistentry> <varlistentry> <term> <constant>FILE_SKIP_EMPTY_LINES</constant> </term> <listitem> <simpara> Skip empty lines </simpara> </listitem> </varlistentry> </variablelist> </para> </listitem> </varlistentry> <varlistentry> <term><parameter>context</parameter></term> <listitem> <para> A context resource created with the <function>stream_context_create</function> function. </para> <para> ¬e.context-support; </para> </listitem> </varlistentry> </variablelist> </para> </refsect1> <refsect1 role="returnvalues"> &reftitle.returnvalues; <para> Returns the file in an array. Each element of the array corresponds to a line in the file, with the newline still attached. Upon failure, <function>file</function> returns &false;. </para> <note> <para> Each line in the resulting array will include the line ending, unless <constant>FILE_IGNORE_NEW_LINES</constant> is used. </para> </note> ¬e.line-endings; </refsect1> <refsect1 role="errors"> &reftitle.errors; <para> Emits an <constant>E_WARNING</constant> level error if the file does not exist. </para> </refsect1> <refsect1 role="examples"> &reftitle.examples; <para> <example> <title><function>file</function> example</title> <programlisting role="php"> <![CDATA[ <?php // Get a file into an array. In this example we'll go through HTTP to get // the HTML source of a URL. $lines = file('http://www.example.com/'); // Loop through our array, show HTML source as HTML source; and line numbers too. foreach ($lines as $line_num => $line) { echo "Line #<b>{$line_num}</b> : " . htmlspecialchars($line) . "<br />\n"; } // Another example, let's get a web page into a string. See also file_get_contents(). $html = implode('', file('http://www.example.com/')); // Using the optional flags parameter since PHP 5 $trimmed = file('somefile.txt', FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES); ?> ]]> </programlisting> </example> </para> </refsect1> <refsect1 role="notes"> &reftitle.notes; &warn.ssl-non-standard; </refsect1> <refsect1 role="seealso"> &reftitle.seealso; <para> <simplelist> <member><function>readfile</function></member> <member><function>fopen</function></member> <member><function>fsockopen</function></member> <member><function>popen</function></member> <member><function>file_get_contents</function></member> <member><function>include</function></member> <member><function>stream_context_create</function></member> </simplelist> </para> </refsect1> </refentry> <!-- Keep this comment at the end of the file Local variables: mode: sgml sgml-omittag:t sgml-shorttag:t sgml-minimize-attributes:nil sgml-always-quote-attributes:t sgml-indent-step:1 sgml-indent-data:t indent-tabs-mode:nil sgml-parent-document:nil sgml-default-dtd-file:"~/.phpdoc/manual.ced" sgml-exposed-tags:nil sgml-local-catalogs:nil sgml-local-ecat-files:nil End: vim600: syn=xml fen fdm=syntax fdl=2 si vim: et tw=78 syn=sgml vi: ts=1 sw=1 -->