Package org.apache.avro.file
Class DataFileReader<D>
java.lang.Object
org.apache.avro.file.DataFileStream<D>
org.apache.avro.file.DataFileReader<D>
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Iterable<D>,- Iterator<D>,- FileReader<D>
Random access to files written with 
DataFileWriter.- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class org.apache.avro.file.DataFileStreamDataFileStream.Header
- 
Constructor SummaryConstructorsModifierConstructorDescriptionDataFileReader(File file, DatumReader<D> reader) Construct a reader for a file.DataFileReader(SeekableInput sin, DatumReader<D> reader) Construct a reader for a file.protectedDataFileReader(SeekableInput sin, DatumReader<D> reader, boolean closeOnError, byte[] magic) Construct a reader for a file.protectedDataFileReader(SeekableInput sin, DatumReader<D> reader, DataFileStream.Header header) Construct using aDataFileStream.Header.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidstatic <D> FileReader<D> openReader(File file, DatumReader<D> reader) Open a reader for a file.static <D> FileReader<D> openReader(SeekableInput in, DatumReader<D> reader) Open a reader for a file.static <D> DataFileReader<D> openReader(SeekableInput in, DatumReader<D> reader, DataFileStream.Header header, boolean sync) Construct a reader for a file at the current position of the input, without reading the header.booleanpastSync(long position) Return true if past the next synchronization point after a position.longReturn the last synchronization point before our current position.voidseek(long position) Move to a specific, known synchronization point, one returned fromDataFileWriter.sync()while writing.voidsync(long position) Move to the next synchronization point after a position.longtell()Return the current position in the input.Methods inherited from class org.apache.avro.file.DataFileStreamclose, getBlockCount, getBlockSize, getHeader, getMeta, getMetaKeys, getMetaLong, getMetaString, getSchema, hasNext, iterator, next, next, nextBlock, removeMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.avro.file.FileReadergetSchema, nextMethods inherited from interface java.lang.IterableforEach, iterator, spliteratorMethods inherited from interface java.util.IteratorforEachRemaining, hasNext, next, remove
- 
Constructor Details- 
DataFileReaderConstruct a reader for a file. For example,if you want to read a file record,you need to close the resource. You can use try-with-resource as follows:try (FileReader dataFileReader = DataFileReader.openReader(file,datumReader)) { //Consume the reader } catch (IOException e) { throw new RunTimeIOException(e,"Failed to read metadata for file: %s", file); } - Throws:
- IOException
 
- 
DataFileReaderConstruct a reader for a file. For example,if you want to read a file record,you need to close the resource. You can use try-with-resource as follows:try (FileReader dataFileReader = DataFileReader.openReader(file,datumReader)) { //Consume the reader } catch (IOException e) { throw new RunTimeIOException(e,"Failed to read metadata for file: %s", file); } - Throws:
- IOException
 
- 
DataFileReaderprotected DataFileReader(SeekableInput sin, DatumReader<D> reader, boolean closeOnError, byte[] magic) throws IOException Construct a reader for a file. Please close resource files yourself.- Throws:
- IOException
 
- 
DataFileReaderprotected DataFileReader(SeekableInput sin, DatumReader<D> reader, DataFileStream.Header header) throws IOException - Throws:
- IOException
 
 
- 
- 
Method Details- 
openReaderOpen a reader for a file.- Throws:
- IOException
 
- 
openReaderpublic static <D> FileReader<D> openReader(SeekableInput in, DatumReader<D> reader) throws IOException Open a reader for a file.- Throws:
- IOException
 
- 
openReaderpublic static <D> DataFileReader<D> openReader(SeekableInput in, DatumReader<D> reader, DataFileStream.Header header, boolean sync) throws IOException Construct a reader for a file at the current position of the input, without reading the header.- Parameters:
- sync- True to read forward to the next sync point after opening, false to assume that the input is already at a valid sync point.
- Throws:
- IOException
 
- 
seekMove to a specific, known synchronization point, one returned fromDataFileWriter.sync()while writing. If synchronization points were not saved while writing a file, usesync(long)instead.- Throws:
- IOException
 
- 
syncMove to the next synchronization point after a position. To process a range of file entires, call this with the starting position, then checkpastSync(long)with the end point before each call toDataFileStream.next().- Specified by:
- syncin interface- FileReader<D>
- Throws:
- IOException
 
- 
blockFinished- Overrides:
- blockFinishedin class- DataFileStream<D>
- Throws:
- IOException
 
- 
previousSyncpublic long previousSync()Return the last synchronization point before our current position.
- 
pastSyncReturn true if past the next synchronization point after a position.- Specified by:
- pastSyncin interface- FileReader<D>
- Throws:
- IOException
 
- 
tellDescription copied from interface:FileReaderReturn the current position in the input.- Specified by:
- tellin interface- FileReader<D>
- Throws:
- IOException
 
 
-