DBF extractor C# Exercise - C# Programming Course

 Lesson

File Management

 Exercise

DBF extractor

 Objetive

Create a program that displays the list of fields stored in a DBF file.

The DBF format is used by the old dBase database manager and is still supported as an export format by many current tools, such as Excel or Access.

DBF files are divided into two parts: a header that stores information about the structure of the file and a data zone.

The header zone is separated from the data zone with the CR character (carriage return, number 13 of the ASCII code). The header is divided into two parts: the first occupies 32 bytes and contains general information about the file, while the second contains information about each field and is made up of as many blocks of 32 bytes as there are fields in the table.

The general header of the file is:

Position Size (bytes) Description
1 1 Number that identifies the product with which the table was created
2 3 Last update date in the format of year/month/day
5 4 Total number of records in the table (in reverse order)
9 2 Total length of the header, including CR
11 2 Length of each record, including the delete flag character
13 2 Reserved
15 1 Active Transaction Flag
16 1 Encryption Flag
17 12 Indicators for local area network use
29 1 Flag indicating whether the file has an associated .MDX file
30 3 Reserved

The header of each field is:

Position Size (bytes) Description
1 11 Field Name
12 1 Field Type (C, D, F, L, M, N)
13 4 Reserved
17 1 Field Length
18 1 Number of decimal places if the field is numeric; also used for large character fields
19 2 Reserved
21 1 Work area Flag
22 10 Reserved
32 1 Flag indicating inclusion in the index .MDX

(Note that the number of fields is not indicated in the header, but it can be deduced by knowing the length of the header, which is in positions 9 and 10, and the size of each header block, which is 32 bytes.)

 Example Code

// Importing necessary namespaces
using System;
using System.IO;
using System.Text;

class DBFExtractor
{
    // Main method where the program execution begins
    static void Main()
    {
        // File path (change this to the DBF file you want to extract fields from)
        string filePath = "example.dbf";

        // Call the ExtractFields method to display the list of fields from the DBF file
        ExtractFields(filePath);
    }

    // Method to extract and display the list of fields from the DBF file
    static void ExtractFields(string filePath)
    {
        try
        {
            // Open the DBF file in binary read mode
            using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read))
            {
                // Read the general header (32 bytes)
                byte[] header = new byte[32];
                fs.Read(header, 0, 32);

                // Extract the total length of the header (in bytes) from positions 9-10 (little-endian)
                int headerLength = BitConverter.ToInt16(header, 9);

                // The number of fields can be deduced from the header length
                int fieldCount = (headerLength - 32) / 32;

                // Skip to the start of the field headers
                fs.Seek(32, SeekOrigin.Begin);

                // Read each field header (32 bytes per field)
                for (int i = 0; i < fieldCount; i++)
                {
                    byte[] fieldHeader = new byte[32];
                    fs.Read(fieldHeader, 0, 32);

                    // Extract field name (first 11 bytes)
                    string fieldName = Encoding.ASCII.GetString(fieldHeader, 0, 11).Trim();

                    // Extract field type (12th byte)
                    char fieldType = (char)fieldHeader[11];

                    // Extract field length (17th byte)
                    byte fieldLength = fieldHeader[16];

                    // Display the extracted field information
                    Console.WriteLine($"Field {i + 1}: Name = {fieldName}, Type = {fieldType}, Length = {fieldLength}");
                }
            }
        }
        catch (Exception ex)
        {
            // Catch any errors (like file not found) and display the error message
            Console.WriteLine("Error: " + ex.Message);
        }
    }
}

More C# Exercises of File Management

 Writing to a text file
Create a program to ask the user for several sentences (until they just press Enter) and store them in a text file named "sentences.txt"...
 Appending to a text file
Create a program to ask the user for several sentences (until they just press Enter) and store them in a text file named "sentences.txt". If the file ...
 Display file contents
Create a program to display all the contents of a text file on screen (note: you must use a StreamReader). The name of the file will be entered in the...
 Extended TextToHTML (files)
Expand the TextToHtml class, so that ir can dump it result to a text file. Create a method ToFile, which will receive the name of the file as a parame...
 Logger
Create a class Logger, with a static method Write, which will append a certain text to a file: Logger.Write("myLog.txt", "This text is being logged");...
 More
Create a program which behaves like the Unix command "more": it must display the contents of a text file, and ask the user to press Enter each time th...
 Text replacer
Create a program to replace words in a text file, saving the result into a new file. The file, the word to search and word to replace it with must ...
 Count letters in a file
Create a program to count the amount of times that a certain character is inside a file (of any kind). The file and the letter can be asked to the ...
 Reading a binary file (1: BMP)
Create a C# program to check if a BMP image file seems to be correct. It must see if the first two bytes are B and M (ASCII codes 0x42 and 0x4D). ...
 Writing to a binary file
Create a program which asks the user for his name, his age (byte) and the year in which he was born (int) and stores them in a binary file. Create ...
 C# to Java
Create a basic C# to Java translator. It must accept a C# source files, and create an equivalent Java source file. It will receive the file name in...
 Invert a text file
Create a program to "invert" the contents of a text file: create a file with the same name ending in ".tnv" and containing the same lines as the origi...
 Reading a binay file (2 - GIF)
Create a C# program to check if a GIF image file seems to be correct. It must see if the first four bytes are G, I, F, 8. In case it seems corre...
 Friends database, using files
Expand the "friends database", so that it loads data from file at the beginning of each session (if the file exists) and saves the data to file when t...
 Pascal to C# translator
Create a basic Pascal to C# translator. It will accept program such as: example program; var i: integer; max: integer; begin writeLn("How ...
 Convert a text file to uppercase
Write a program to read a text file and dump its content to another file, changing the lowercase letters to uppercase. You must deliver only the "....
 Convert any file to uppercase
Write a program to read a file (of any kind) and dump its content to another file, changing the lowercase letters to uppercase. You must deliver on...
 File inverter
Create a program to "invert" a file: create a file with the same name ending in ".inv" and containing the same bytes as the original file but in rever...
 File encrypter
Create a program to encrypt a text file into another text file....
 Count words
Create a C# program to count the amount of words stored in a text file...
 BMP width and height, BinaryReader
Create a C# program to display the width and height of a BMP file using a BinaryReader. The structure of the header of a BMP file is: File type ...
 TXT to HTML translator
Create a "Text to HTML converter", which will read a source text file and create a HTML file from its contents. For example, if the file contains: Ho...
 Invert binary file V2
Create a program to "invert" a file using a "FileStream". The program should create a file with the same name ending in ".inv" and containing the same...
 BMP width & height, FileStream
Create a C# program to display the width and height of a BMP file using a FileStream. Remember the structure of the BMP header: File type (lette...
 File copier
Create a program to copy a source file to a destination file. You must use FileStream and a block size of 512 KB. An example usage might be: mycopy...
 MP3 reader
ID3 specifications apply to any file or audiovisual container, but they are primarily used with audio containers. There are three compatible versions ...
 C to C# converter
Create a program to convert simple C programs, such as the following one, to C#: Note: the resulting program must compile correctly. Test it with oth...
 File splitter
Create a program to split a file (of any kind) into pieces of a certain size. It must receive the name of the file and the size as parameters. For exa...
 Encrypt a BMP file
Create a program to encrypt/decrypt a BMP image file by changing the "BM" mark in the first two bytes to "MB" and vice versa. Use the advanced File...
 CSV converter
The CSV ("Comma Separated Values") is an exchange format used by many spreadsheet and database management systems. It consists of a series of comma-se...
 File comparer
Create a C# program to tell if two files (of any kind) are identical (have the same content)....
 Display BPM on console
The Netpbm format is a family of image file formats designed with simplicity in mind, rather than small size. They can represent color, grayscale, or ...
 PCX width and height
Create a program that checks if a file is a PCX image and, if so, displays its width and height using the following specification: What is the PCX ...
 Extract text from a binary file
Create a program that extracts only the alphabetic characters contained in a binary file and dumps them to a separate file. The extracted characters s...
 C# to Pascal converter
Create a program that converts simple C# programs, such as the following one, to the Pascal language....
 Dump
Create a "dump" utility: a hex viewer that displays the contents of a file, with 16 bytes in each row and 24 rows in each screen. The program should p...
 Text censorer
Create a program to censor text files. It should read a text file and dump its results to a new text file, replacing certain words with "[CENSORED]". ...
 SQL to text
You must create a C# program that is capable of parsing SQL INSERT commands and extracting their data into separate lines of text, as follows. If the ...
 PGM viewer
The PGM format is one of the versions of NetPBM image formats. Specifically, it is the variant capable of handling images in shades of gray. Its he...
 Display BMP on console V2
Create a program to display a 72x24 BMP file on the console. You must use the information in the BMP header (refer to the exercise of Feb. 7th). Pay a...

Juan A. Ripoll - Programming Tutorials and Courses © 2025 All rights reserved.  Legal Conditions.