You can read the data by constructing an instance of ParquetReader class or using one of the static helper methods on the ParquetReader
class, like ParquetReader.OpenFromFile()
.
Reading files is a multi stage process, giving you the full flexibility on what exactly to read from it:
- Create
ParquetReader
from a source stream or open it with any utility method. Once the reader is open you can immediately access file schema and other global file options like key-value metadata and number of row groups. - Open
RowGroupReader
by calling toreader.OpenRowGroupReader(groupIndex)
. This class also exposes general row group properties like row count. - Call
.Read()
on row group reader passing theDataField
schema definition you wish to read. - Returned
DataColumn
contains the column data. Important thing to note here is we automatically merge data and definition levels of the column so that.Data
member of typeSystem.Array
contains actual usable column data. Note that we do not process repetition levels if the column is a part of a more complex structure, and you have to use them appropriately. Simple data columns do not contain repetition levels.
It's worth noting that repetition levels are only used for complex data types like arrays, list and maps. Processing them automatically would add an enormous performance overhead, therefore we are leaving it up to you to decide how to use them.
When reading, Parquet.Net uses some defaults specified in ParquetOptions.cs, however you can override them by passing to a ParquetReader
constructor.
For example, to force the reader to treat byte arrays as strings use the following code:
var options = new ParquetOptions { TreatByteArrayAsString = true };
var reader = await ParquetReader.CreateAsync(stream, options);
To read custom metadata you can access the CustomMetadata
property on ParquetReader
:
using (var reader = await ParquetReader.CreateAsync(ms))
{
Assert.Equal("value1", reader.CustomMetadata["key1"]);
Assert.Equal("value2", reader.CustomMetadata["key2"]);
}