Filtrar Leer y escribir en un archivo de datos recién creadoHow to: Read and write to a newly created data file

Las clases System.IO.BinaryWriter y System.IO.BinaryReader se usan para escribir y leer datos distintos de cadenas de caracteres.The System.IO.BinaryWriter and System.IO.BinaryReader classes are used for writing and reading data other than character strings. En el ejemplo siguiente se muestra cómo se crea un flujo de archivos vacío y cómo se escriben y se leen datos de este.The following example shows how to create an empty file stream, write data to it, and read data from it.

El ejemplo crea un archivo de datos llamado Test.data en el directorio actual, crea los objetos BinaryWriter y BinaryReader asociados y usa el objeto BinaryWriter para escribir los enteros de 0 a 10 en Test.data, que deja el puntero de archivo al final del archivo.The example creates a data file called Test.data in the current directory, creates the associated BinaryWriter and BinaryReader objects, and uses the BinaryWriter object to write the integers 0 through 10 to Test.data, which leaves the file pointer at the end of the file. A continuación, el objeto BinaryReader vuelve a establecer el puntero de archivo en el origen y lee el contenido especificado.The BinaryReader object then sets the file pointer back to the origin and reads out the specified content.

Nota

Si Test.data ya existe en el directorio actual, se genera una excepción IOException.If Test.data already exists in the current directory, an IOException exception is thrown. Use la opción de modo de archivo FileMode.Create en lugar de FileMode.CreateNew para crear siempre un archivo nuevo sin generar una excepción.Use the file mode option FileMode.Create rather than FileMode.CreateNew to always create a new file without throwing an exception.

EjemploExample

using System;
using System.IO;

class MyStream
{
    private const string FILE_NAME = "Test.data";

    public static void Main()
    {
        if (File.Exists(FILE_NAME))
        {
            Console.WriteLine($"{FILE_NAME} already exists!");
            return;
        }

        using (FileStream fs = new FileStream(FILE_NAME, FileMode.CreateNew))
        {
            using (BinaryWriter w = new BinaryWriter(fs))
            {
                for (int i = 0; i < 11; i++)
                {
                    w.Write(i);
                }
            }
        }
        
        using (FileStream fs = new FileStream(FILE_NAME, FileMode.Open, FileAccess.Read))
        {
            using (BinaryReader r = new BinaryReader(fs))
            {
                for (int i = 0; i < 11; i++)
                {
                    Console.WriteLine(r.ReadInt32());
                }
            }
        }
    }
}


// The example creates a file named "Test.data" and writes the integers 0 through 10 to it in binary format.
// It then writes the contents of Test.data to the console with each integer on a separate line.
Imports System.IO

Class MyStream
    Private Const FILE_NAME As String = "Test.data"

    Public Shared Sub Main()
        If File.Exists(FILE_NAME) Then
            Console.WriteLine($"{FILE_NAME} already exists!")
            Return
        End If

        Using fs As New FileStream(FILE_NAME, FileMode.CreateNew)
            Using w As New BinaryWriter(fs)
                For i As Integer = 0 To 10
                    w.Write(i)
                Next
            End Using
        End Using

        Using fs As New FileStream(FILE_NAME, FileMode.Open, FileAccess.Read)
            Using r As New BinaryReader(fs)
                For i As Integer = 0 To 10
                    Console.WriteLine(r.ReadInt32())
                Next
            End Using
        End Using
    End Sub
End Class

' The example creates a file named "Test.data" and writes the integers 0 through 10 to it in binary format.
' It then writes the contents of Test.data to the console with each integer on a separate line.

Vea tambiénSee also