File Handling
A file is a collection of data stored in a disk with a specific name and a directory
path. When a file is opened for reading or writing, it becomes a stream.
The stream is basically the sequence of bytes passing through the communication
path. There are two main streams: the input stream and the output stream. The
input stream is used for reading data from file (read operation) and the output
stream is used for writing into the file (write operation).
VB.Net I/O Classes
The System.IO namespace has various classes that are used for performing various
operations with files, like creating and deleting files, reading from or writing to a
file, closing a file, etc.
The following table shows Description
some commonly used non-
abstract classes in the
System.IO namespace: I/O
Class
BinaryReader Reads primitive data from a
binary stream.
BinaryWriter Writes primitive data in binary
format.
BufferedStream A temporary storage for a
stream of bytes.
Directory Helps in manipulating a
directory structure.
DirectoryInfo Used for performing
operations on directories.
DriveInfo Provides information for the
drives.
File Helps in manipulating files.
FileInfo Used for performing
operations on files.
FileStream Used to read from and write to any
location in a file.
MemoryStream Used for random access of streamed
data stored in memory.
Path Performs operations on path
information.
StreamReader Used for reading characters from a
byte stream.
StreamWriter Is used for writing characters to a
stream.
StringReader Is used for reading from a string
buffer.
StringWriter Is used for writing into a string
buffer.
Reading from and Writing to Text Files
The StreamReader and StreamWriter classes are used for reading from and
writing data to text files. These classes inherit from the abstract base class Stream,
which supports reading and writing bytes into a file stream.
The StreamReader Class
The StreamReader class represents a reader for reading series of characters. The
following table describes some of the commonly used methods of the
StreamReader class.
Public Overrides Sub Close.
It closes the StreamReader object and the underlying stream and releases any
system resources associated with the reader.
Public Overrides Function Peek As Integer.
Returns the next available character but does not consume it.
Public Overrides Function Read As Integer
Reads the next character from the input stream and advances the character position
by one character.
Example
The following example demonstrates reading a text file named programming.txt.
The file reads:
Computer Programming
The purpose of programming is to find a sequence of instructions that will
automate the performance of a task on a computer, often for solving a given
problem. In essence, programming can be described as an art writing a set of
instructions to solve a particular problem
Imports System.IO
Module fileProg
Sub Main()
Try
' Create an instance of StreamReader to read from a file.
' The using statement also closes the StreamReader.
Using sr As StreamReader = New StreamReader("c:/programming.txt")
Dim line As String
' Read and display lines from the file until the end of
' the file is reached.
line = sr.ReadLine()
While (line <> Nothing)
Console.WriteLine(line)
line = sr.ReadLine()
End While
End Using
Catch e As Exception
' Let the user know what went wrong.
Console.WriteLine("The file could not be read:")
Console.WriteLine(e.Message)
End Try
Console.ReadKey()
End Sub
End Module
The StreamWriter Class
The StreamWriter class represents a writer, which can write a series of character.
The following shows some of the most commonly used methods of this class:
Public Overrides Sub Close
Closes the current StreamWriter object and the underlying
stream.
Public Overrides Sub Flush
Clears all buffers for the current writer and causes any buffered data
to be written to the underlying stream.
Public Overridable Sub Write (value As Boolean)
Writes the text representation of a Boolean value to the text string
or stream. (Inherited from TextWriter.)
Public Overrides Sub Write (value As
Char)
Writes a character to the stream.
Public Overridable Sub Write (value As Decimal)
Writes the text representation of a decimal value to the text string
or stream.
Public Overridable Sub Write (value As Double)
Writes the text representation of an 8-byte floating-point value to
the text string or stream.
Public Overridable Sub Write (value As Integer)
Writes the text representation of a 4-byte signed integer to the
text string or stream.
Public Overrides Sub Write (value As
String)
Writes a string to the stream.
Public Overridable Sub WriteLine
Writes a line terminator to the text string or
stream.
Example
The following example demonstrates writing text data into a file using the
StreamWriter class:
Imports System.IO
Module fileProg
Sub Main()
Dim names As String() = New String() {"Zara Ali", _
"Nuha Ali", "Amir Sohel", "M Amlan"}
Dim s As String
Using sw As StreamWriter = New StreamWriter("names.txt")
For Each s In names
sw.WriteLine(s)
Next s
End Using
' Read and show each line from the file.
Dim line As String
Using sr As StreamReader = New StreamReader("names.txt")
line = sr.ReadLine()
While (line <> Nothing)
Console.WriteLine(line)
line = sr.ReadLine()
End While
End Using
Console.ReadKey()
End Sub
End Module