Procédure : lire et écrire dans un fichier de données créé récemmentHow to: Read and write to a newly created data file

Les classes System.IO.BinaryWriter et System.IO.BinaryReader sont utilisées pour écrire et lire des données autres que des chaînes de caractères.The System.IO.BinaryWriter and System.IO.BinaryReader classes are used for writing and reading data other than character strings. L’exemple suivant montre comment créer un flux de fichier vide, y écrire des données, puis les lire.The following example shows how to create an empty file stream, write data to it, and read data from it.

L’exemple créé un fichier de données appelé Test.data dans le répertoire actif, crée les objets BinaryWriter et BinaryReader associés, puis utilise l’objet BinaryWriter pour écrire les entiers de 0 à 10 dans Test.data, ce qui laisse le pointeur de fichier à la fin du fichier.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. Ensuite, l’objet BinaryReader replace le pointeur de fichier au début, puis lit le contenu spécifié.The BinaryReader object then sets the file pointer back to the origin and reads out the specified content.

Notes

Si Test.data existe déjà dans le répertoire actif, une exception IOException est levée.If Test.data already exists in the current directory, an IOException exception is thrown. Utilisez l’option de mode de fichier FileMode.Create plutôt que FileMode.CreateNew pour toujours créer un fichier sans lever d’exception.Use the file mode option FileMode.Create rather than FileMode.CreateNew to always create a new file without throwing an exception.

ExempleExample

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.

Voir aussiSee also