Reads entire file into an array (original) (raw)
(PHP 4, PHP 5, PHP 7)
file — Reads entire file into an array
Description
file ( string $filename
[, int $flags
= 0 [, resource $context
]] ) : array
Note:
You can use file_get_contents() to return the contents of a file as a string.
Parameters
filename
Path to the file.
Tip
A URL can be used as a filename with this function if the fopen wrappers have been enabled. See fopen() for more details on how to specify the filename. See the Supported Protocols and Wrappers for links to information about what abilities the various wrappers have, notes on their usage, and information on any predefined variables they may provide.
flags
The optional parameter flags
can be one, or more, of the following constants:
FILE_USE_INCLUDE_PATH
Search for the file in the include_path.
FILE_IGNORE_NEW_LINES
Omit newline at the end of each array element
FILE_SKIP_EMPTY_LINES
Skip empty lines
context
A context resource created with the stream_context_create() function.
Note: Context support was added with PHP 5.0.0. For a description of
contexts
, refer toStreams.
Return Values
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,file() returns FALSE
.
Note:
Each line in the resulting array will include the line ending, unless**
FILE_IGNORE_NEW_LINES
** is used.
Note: If PHP is not properly recognizing the line endings when reading files either on or created by a Macintosh computer, enabling theauto_detect_line_endingsrun-time configuration option may help resolve the problem.
Errors/Exceptions
Emits an E_WARNING
level error if the file does not exist.
Examples
Example #1 file() example
<?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 <span class="katex"><span class="katex-mathml"><math xmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mi>l</mi><mi>i</mi><mi>n</mi><msub><mi>e</mi><mi>n</mi></msub><mi>u</mi><mi>m</mi><mo>=</mo><mo>></mo></mrow><annotation encoding="application/x-tex">line_num => </annotation></semantics></math></span><span class="katex-html" aria-hidden="true"><span class="base"><span class="strut" style="height:0.8444em;vertical-align:-0.15em;"></span><span class="mord mathnormal" style="margin-right:0.01968em;">l</span><span class="mord mathnormal">in</span><span class="mord"><span class="mord mathnormal">e</span><span class="msupsub"><span class="vlist-t vlist-t2"><span class="vlist-r"><span class="vlist" style="height:0.1514em;"><span style="top:-2.55em;margin-left:0em;margin-right:0.05em;"><span class="pstrut" style="height:2.7em;"></span><span class="sizing reset-size6 size3 mtight"><span class="mord mathnormal mtight">n</span></span></span></span><span class="vlist-s"></span></span><span class="vlist-r"><span class="vlist" style="height:0.15em;"><span></span></span></span></span></span></span><span class="mord mathnormal">u</span><span class="mord mathnormal">m</span><span class="mspace" style="margin-right:0.2778em;"></span><span class="mrel">=></span></span></span></span>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); ?>
Notes
Warning
When using SSL, Microsoft IIS will violate the protocol by closing the connection without sending aclose_notify
indicator. PHP will report this as "SSL: Fatal Protocol Error" when you reach the end of the data. To work around this, the value of error_reporting should be lowered to a level that does not include warnings. PHP can detect buggy IIS server software when you open the stream using the https://
wrapper and will suppress the warning. When using fsockopen() to create anssl://
socket, the developer is responsible for detecting and suppressing this warning.
See Also
- readfile() - Outputs a file
- fopen() - Opens file or URL
- fsockopen() - Open Internet or Unix domain socket connection
- popen() - Opens process file pointer
- file_get_contents() - Reads entire file into a string
- include - include
- stream_context_create() - Creates a stream context