fgets

(PHP 4, PHP 5, PHP 7, PHP 8)

fgetsRecupera la línea actual a partir de la posición del puntero de archivo

Descripción

fgets(resource $stream, ?int $length = null): string|false

Recupera la línea actual a partir de la posición del puntero de archivo.

Parámetros

stream

El puntero de archivo debe ser válido y apuntar a un archivo abierto con éxito por fopen() o fsockopen() (y no cerrado aún por fclose()).

length

Lee hasta la longitud length - 1 byte desde el puntero de archivo stream, o bien el final del archivo, o una nueva línea (que es incluida en el valor devuelto), o un EOF (el que llegue primero). Si no se proporciona longitud, la función leerá el flujo hasta el final de la línea.

Valores devueltos

Devuelve un string que contiene los length primeros caracteres, menos 1 byte desde el puntero de archivo stream. false es devuelto si no hay más datos para leer.

Si ocurre un error, la función devuelve false.

Ejemplos

Ejemplo #1 Lectura de un archivo línea por línea

<?php

$fp
= @fopen("/tmp/inputfile.txt", "r");

if (
$fp) {
while ((
$buffer = fgets($fp, 4096)) !== false) {
echo
$buffer, PHP_EOL;
}
if (!
feof($fp)) {
echo
"Error: fgets() falló\n";
}

fclose($fp);
}

?>

Notas

Nota: Si PHP no reconoce correctamente los finales de línea al leer archivos que han sido creados o leídos en un Macintosh, la activación de la opción de configuración auto_detect_line_endings puede resolver el problema.

Nota:

Los programadores acostumbrados a la programación 'C' notarán que fgets() no se comporta como su equivalente en C al encontrar el final del archivo.

Ver también

  • fgetss() - Obtiene un línea desde un puntero a un archivo y elimina las etiquetas HTML
  • fread() - Lectura del archivo en modo binario
  • fgetc() - Lee un carácter en un fichero
  • stream_get_line() - Lee una línea en un flujo
  • fopen() - Abre un fichero o un URL
  • popen() - Crea un puntero de archivo de proceso
  • fsockopen() - Abre un socket de conexión Internet o Unix
  • stream_set_timeout() - Configura el tiempo de espera de un flujo