apache_beam.io.filesystemio module¶
Utilities for FileSystem
implementations.
-
class
apache_beam.io.filesystemio.
Downloader
[source]¶ Bases:
future.types.newobject.newobject
Download interface for a single file.
Implementations should support random access reads.
-
size
¶ Size of file to download.
-
get_range
(start, end)[source]¶ Retrieve a given byte range [start, end) from this download.
- Range must be in this form:
- 0 <= start < end: Fetch the bytes from start to end.
Parameters: - start – (int) Initial byte offset.
- end – (int) Final byte offset, exclusive.
Returns: (string) A buffer containing the requested data.
-
-
class
apache_beam.io.filesystemio.
Uploader
[source]¶ Bases:
future.types.newobject.newobject
Upload interface for a single file.
-
class
apache_beam.io.filesystemio.
DownloaderStream
(downloader, mode='rb')[source]¶ Bases:
io.RawIOBase
Provides a stream interface for Downloader objects.
Initializes the stream.
Parameters: - downloader – (Downloader) Filesystem dependent implementation.
- mode – (string) Python mode attribute for this stream.
-
readinto
(b)[source]¶ Read up to len(b) bytes into b.
Returns number of bytes read (0 for EOF).
Parameters: b – (bytearray/memoryview) Buffer to read into.
-
seek
(offset, whence=0)[source]¶ Set the stream’s current offset.
Note if the new offset is out of bound, it is adjusted to either 0 or EOF.
Parameters: - offset – seek offset as number.
- whence – seek mode. Supported modes are os.SEEK_SET (absolute seek), os.SEEK_CUR (seek relative to the current position), and os.SEEK_END (seek relative to the end, offset should be negative).
Raises: ValueError
– When this stream is closed or if whence is invalid.
-
class
apache_beam.io.filesystemio.
UploaderStream
(uploader, mode='wb')[source]¶ Bases:
io.RawIOBase
Provides a stream interface for Uploader objects.
Initializes the stream.
Parameters: - uploader – (Uploader) Filesystem dependent implementation.
- mode – (string) Python mode attribute for this stream.
-
write
(b)[source]¶ Write bytes from b.
Returns number of bytes written (<= len(b)).
Parameters: b – (memoryview) Buffer with data to write.
-
class
apache_beam.io.filesystemio.
PipeStream
(recv_pipe)[source]¶ Bases:
future.types.newobject.newobject
A class that presents a pipe connection as a readable stream.
Not thread-safe.
Remembers the last
size
bytes read and allows rewinding the stream by that amount exactly. See BEAM-6380 for more.-
read
(size)[source]¶ Read data from the wrapped pipe connection.
Parameters: size – Number of bytes to read. Actual number of bytes read is always equal to size unless EOF is reached. Returns: data read as str.
-