Leer en inglés

Compartir a través de


File.ReadLines Método

Definición

Lee las líneas de un archivo.

Sobrecargas

ReadLines(String, Encoding)

Lea las líneas de un archivo que tiene una codificación especificada.

ReadLines(String)

Lee las líneas de un archivo.

ReadLines(String, Encoding)

Source:
File.cs
Source:
File.cs
Source:
File.cs

Lea las líneas de un archivo que tiene una codificación especificada.

C#
public static System.Collections.Generic.IEnumerable<string> ReadLines (string path, System.Text.Encoding encoding);

Parámetros

path
String

Archivo que se va a leer.

encoding
Encoding

Codificación que se aplica al contenido del archivo.

Devoluciones

Todas las líneas del archivo o las líneas que son el resultado de una consulta.

Excepciones

Versiones de .NET Framework y .NET Core anteriores a la 2.1: path es una cadena de longitud cero, solo contiene espacios en blanco o contiene uno o varios caracteres no válidos según lo definido por el método GetInvalidPathChars().

path es null.

path no es válido (por ejemplo, se encuentra en una unidad no asignada).

No se encontró el archivo especificado por path.

Error de E/S al abrir el archivo.

path supera la longitud máxima definida por el sistema.

El autor de la llamada no tiene el permiso necesario.

path especifica un archivo que es de solo lectura.

-o-

Esta operación no se admite en la plataforma actual.

-o-

path es un directorio.

-o-

El autor de la llamada no tiene el permiso necesario.

Comentarios

Use este método para especificar una codificación que se usará para leer el archivo.

Los métodos ReadLines y ReadAllLines difieren de la siguiente manera: cuando se usa ReadLines, puede empezar a enumerar la colección de cadenas antes de que se devuelva toda la colección. Cuando se usa ReadAllLines, debe esperar a que se devuelva toda la matriz de cadenas para poder acceder a la matriz. Por lo tanto, cuando se trabaja con archivos muy grandes, ReadLines puede ser más eficaz.

Puede usar el método ReadLines para hacer lo siguiente:

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

ReadLines(String)

Source:
File.cs
Source:
File.cs
Source:
File.cs

Lee las líneas de un archivo.

C#
public static System.Collections.Generic.IEnumerable<string> ReadLines (string path);

Parámetros

path
String

Archivo que se va a leer.

Devoluciones

Todas las líneas del archivo o las líneas que son el resultado de una consulta.

Excepciones

Versiones de .NET Framework y .NET Core anteriores a la 2.1: path es una cadena de longitud cero, solo contiene espacios en blanco o contiene uno o varios caracteres no válidos definidos por el método GetInvalidPathChars().

path es null.

path no es válido (por ejemplo, se encuentra en una unidad no asignada).

No se encontró el archivo especificado por path.

Error de E/S al abrir el archivo.

path supera la longitud máxima definida por el sistema.

El autor de la llamada no tiene el permiso necesario.

path especifica un archivo que es de solo lectura.

-o-

Esta operación no se admite en la plataforma actual.

-o-

path es un directorio.

-o-

El autor de la llamada no tiene el permiso necesario.

Ejemplos

En el ejemplo siguiente se leen las líneas de un archivo para buscar líneas que contienen cadenas especificadas.

C#
foreach (string line in File.ReadLines(@"d:\data\episodes.txt"))
{
    if (line.Contains("episode") & line.Contains("2006"))
    {
        Console.WriteLine(line);
    }
}

En el ejemplo siguiente se usa el método ReadLines en una consulta LINQ que enumera todos los directorios de los archivos que tienen una extensión .txt, lee cada línea del archivo y muestra la línea si contiene la cadena "Microsoft".

C#
using System;
using System.IO;
using System.Linq;

class Program
{
    static void Main(string[] args)
    {
        try
        {
            // Set a variable to the My Documents path.
            string docPath =
            Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments);

            var files = from file in Directory.EnumerateFiles(docPath, "*.txt", SearchOption.AllDirectories)
                        from line in File.ReadLines(file)
                        where line.Contains("Microsoft")
                        select new
                        {
                            File = file,
                            Line = line
                        };

            foreach (var f in files)
            {
                Console.WriteLine($"{f.File}\t{f.Line}");
            }
            Console.WriteLine($"{files.Count().ToString()} files found.");
        }
        catch (UnauthorizedAccessException uAEx)
        {
            Console.WriteLine(uAEx.Message);
        }
        catch (PathTooLongException pathEx)
        {
            Console.WriteLine(pathEx.Message);
        }
    }
}

Comentarios

Los métodos ReadLines y ReadAllLines difieren de la siguiente manera: Cuando se usa ReadLines, puede empezar a enumerar la colección de cadenas antes de que se devuelva toda la colección; cuando se usa ReadAllLines, debe esperar a que se devuelva toda la matriz de cadenas para poder acceder a la matriz. Por lo tanto, cuando se trabaja con archivos muy grandes, ReadLines puede ser más eficaz.

Puede usar el método ReadLines para hacer lo siguiente:

Este método usa UTF8 para el valor de codificación.

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0