Package for working with dBase III plus database files. Default encoding is UTF-8.
- Package provides both reflection-via-struct interface and direct Row()/FieldValueByName()/AddxxxField() interface.
- Once table is created and rows added to it, table structure can not be modified.
- Working with reflection-via-struct interface is easier and produces less verbose code.
- Use Iterator to iterate over table since it skips deleted rows.
When using the struct interface, you can use struct tags to customize field mapping:
type Person struct {
Name string `dbf:"NAME"` // Map to NAME field
Age int `dbf:"AGE,omitempty"` // Map to AGE field, omit if zero
Created time.Time `dbf:"CREATED"` // Map to CREATED field
}The omitempty tag option works similarly to the encoding/json package.
When omitempty is specified for a field, that field will only be written
if its value is not the zero value for its type.
Typical usage db := dbf.New() or dbf.LoadFile(filename)
then use db.NewIterator() and iterate or db.Append()
do not forget db.SaveFile(filename) if you want changes saved.
File is loaded and kept in-memory. Not a good design choice if file is huge. This should be changed to use buffers and keep some of the data on-disk in the future. Current API structure should allow redesign.
Look into cmd directory for examples of use and basic tools to load and export into CSV files.
Copyright (C) Tad Vizbaras. Released under MIT license.