pyarrow.fs.LocalFileSystem¶
- class pyarrow.fs.LocalFileSystem(use_mmap=False, *)¶
Bases:
FileSystem
A FileSystem implementation accessing files on the local machine.
Details such as symlinks are abstracted away (symlinks are always followed, except when deleting an entry).
- Parameters:
Examples
Create a FileSystem object with LocalFileSystem constructor:
>>> from pyarrow import fs >>> local = fs.LocalFileSystem() >>> local <pyarrow._fs.LocalFileSystem object at ...>
and write data on to the file:
>>> with local.open_output_stream('/tmp/local_fs.dat') as stream: ... stream.write(b'data') 4 >>> with local.open_input_stream('/tmp/local_fs.dat') as stream: ... print(stream.readall()) b'data'
Create a FileSystem object inferred from a URI of the saved file:
>>> local_new, path = fs.LocalFileSystem().from_uri('/tmp/local_fs.dat') >>> local_new <pyarrow._fs.LocalFileSystem object at ... >>> path '/tmp/local_fs.dat'
Check if FileSystems local and local_new are equal:
>>> local.equals(local_new) True
Compare two different FileSystems:
>>> local2 = fs.LocalFileSystem(use_mmap=True) >>> local.equals(local2) False
Copy a file and print out the data:
>>> local.copy_file('/tmp/local_fs.dat', '/tmp/local_fs-copy.dat') >>> with local.open_input_stream('/tmp/local_fs-copy.dat') as stream: ... print(stream.readall()) ... b'data'
Open an output stream for appending, add text and print the new data:
>>> with local.open_append_stream('/tmp/local_fs-copy.dat') as f: ... f.write(b'+newly added') 12
>>> with local.open_input_stream('/tmp/local_fs-copy.dat') as f: ... print(f.readall()) b'data+newly added'
Create a directory, copy a file into it and then delete the whole directory:
>>> local.create_dir('/tmp/new_folder') >>> local.copy_file('/tmp/local_fs.dat', '/tmp/new_folder/local_fs.dat') >>> local.get_file_info('/tmp/new_folder') <FileInfo for '/tmp/new_folder': type=FileType.Directory> >>> local.delete_dir('/tmp/new_folder') >>> local.get_file_info('/tmp/new_folder') <FileInfo for '/tmp/new_folder': type=FileType.NotFound>
Create a directory, copy a file into it and then delete the content of the directory:
>>> local.create_dir('/tmp/new_folder') >>> local.copy_file('/tmp/local_fs.dat', '/tmp/new_folder/local_fs.dat') >>> local.get_file_info('/tmp/new_folder/local_fs.dat') <FileInfo for '/tmp/new_folder/local_fs.dat': type=FileType.File, size=4> >>> local.delete_dir_contents('/tmp/new_folder') >>> local.get_file_info('/tmp/new_folder') <FileInfo for '/tmp/new_folder': type=FileType.Directory> >>> local.get_file_info('/tmp/new_folder/local_fs.dat') <FileInfo for '/tmp/new_folder/local_fs.dat': type=FileType.NotFound>
Create a directory, copy a file into it and then delete the file from the directory:
>>> local.create_dir('/tmp/new_folder') >>> local.copy_file('/tmp/local_fs.dat', '/tmp/new_folder/local_fs.dat') >>> local.delete_file('/tmp/new_folder/local_fs.dat') >>> local.get_file_info('/tmp/new_folder/local_fs.dat') <FileInfo for '/tmp/new_folder/local_fs.dat': type=FileType.NotFound> >>> local.get_file_info('/tmp/new_folder') <FileInfo for '/tmp/new_folder': type=FileType.Directory>
Move the file:
>>> local.move('/tmp/local_fs-copy.dat', '/tmp/new_folder/local_fs-copy.dat') >>> local.get_file_info('/tmp/new_folder/local_fs-copy.dat') <FileInfo for '/tmp/new_folder/local_fs-copy.dat': type=FileType.File, size=16> >>> local.get_file_info('/tmp/local_fs-copy.dat') <FileInfo for '/tmp/local_fs-copy.dat': type=FileType.NotFound>
To finish delete the file left: >>> local.delete_file(‘/tmp/local_fs.dat’)
- __init__(*args, **kwargs)¶
Methods
__init__
(*args, **kwargs)copy_file
(self, src, dest)Copy a file.
create_dir
(self, path, *, bool recursive=True)Create a directory and subdirectories.
delete_dir
(self, path)Delete a directory and its contents, recursively.
delete_dir_contents
(self, path, *, ...)Delete a directory's contents, recursively.
delete_file
(self, path)Delete a file.
equals
(self, FileSystem other)from_uri
(uri)Create a new FileSystem from URI or Path.
get_file_info
(self, paths_or_selector)Get info for the given files.
move
(self, src, dest)Move / rename a file or directory.
normalize_path
(self, path)Normalize filesystem path.
open_append_stream
(self, path[, ...])Open an output stream for appending.
open_input_file
(self, path)Open an input file for random access reading.
open_input_stream
(self, path[, compression, ...])Open an input stream for sequential reading.
open_output_stream
(self, path[, ...])Open an output stream for sequential writing.
Attributes
The filesystem's type name.
- copy_file(self, src, dest)¶
Copy a file.
If the destination exists and is a directory, an error is returned. Otherwise, it is replaced.
- Parameters:
Examples
>>> local.copy_file(path, ... local_path + '/pyarrow-fs-example_copy.dat')
Inspect the file info:
>>> local.get_file_info(local_path + '/pyarrow-fs-example_copy.dat') <FileInfo for '/.../pyarrow-fs-example_copy.dat': type=FileType.File, size=4> >>> local.get_file_info(path) <FileInfo for '/.../pyarrow-fs-example.dat': type=FileType.File, size=4>
- create_dir(self, path, *, bool recursive=True)¶
Create a directory and subdirectories.
This function succeeds if the directory already exists.
- delete_dir(self, path)¶
Delete a directory and its contents, recursively.
- Parameters:
- path
str
The path of the directory to be deleted.
- path
- delete_dir_contents(self, path, *, bool accept_root_dir=False, bool missing_dir_ok=False)¶
Delete a directory’s contents, recursively.
Like delete_dir, but doesn’t delete the directory itself.
- equals(self, FileSystem other)¶
- static from_uri(uri)¶
Create a new FileSystem from URI or Path.
Recognized URI schemes are “file”, “mock”, “s3fs”, “hdfs” and “viewfs”. In addition, the argument can be a pathlib.Path object, or a string describing an absolute local path.
- Parameters:
- uri
str
URI-based path, for example: file:///some/local/path.
- uri
- Returns:
tuple
of (FileSystem
,str
path)With (filesystem, path) tuple where path is the abstract path inside the FileSystem instance.
Examples
Create a new FileSystem subclass from a URI:
>>> uri = 'file:///{}/pyarrow-fs-example.dat'.format(local_path) >>> local_new, path_new = fs.FileSystem.from_uri(uri) >>> local_new <pyarrow._fs.LocalFileSystem object at ... >>> path_new '/.../pyarrow-fs-example.dat'
Or from a s3 bucket:
>>> fs.FileSystem.from_uri("s3://usgs-landsat/collection02/") (<pyarrow._s3fs.S3FileSystem object at ...>, 'usgs-landsat/collection02')
- get_file_info(self, paths_or_selector)¶
Get info for the given files.
Any symlink is automatically dereferenced, recursively. A non-existing or unreachable file returns a FileStat object and has a FileType of value NotFound. An exception indicates a truly exceptional condition (low-level I/O error, etc.).
- Parameters:
- paths_or_selector
FileSelector
, path-like orlist
of path-likes Either a selector object, a path-like object or a list of path-like objects. The selector’s base directory will not be part of the results, even if it exists. If it doesn’t exist, use allow_not_found.
- paths_or_selector
- Returns:
Examples
>>> local <pyarrow._fs.LocalFileSystem object at ...> >>> local.get_file_info("/{}/pyarrow-fs-example.dat".format(local_path)) <FileInfo for '/.../pyarrow-fs-example.dat': type=FileType.File, size=4>
- move(self, src, dest)¶
Move / rename a file or directory.
If the destination exists: - if it is a non-empty directory, an error is returned - otherwise, if it has the same type as the source, it is replaced - otherwise, behavior is unspecified (implementation-dependent).
- Parameters:
Examples
Create a new folder with a file:
>>> local.create_dir('/tmp/other_dir') >>> local.copy_file(path,'/tmp/move_example.dat')
Move the file:
>>> local.move('/tmp/move_example.dat', ... '/tmp/other_dir/move_example_2.dat')
Inspect the file info:
>>> local.get_file_info('/tmp/other_dir/move_example_2.dat') <FileInfo for '/tmp/other_dir/move_example_2.dat': type=FileType.File, size=4> >>> local.get_file_info('/tmp/move_example.dat') <FileInfo for '/tmp/move_example.dat': type=FileType.NotFound>
Delete the folder: >>> local.delete_dir(‘/tmp/other_dir’)
- normalize_path(self, path)¶
Normalize filesystem path.
- open_append_stream(self, path, compression='detect', buffer_size=None, metadata=None)¶
Open an output stream for appending.
If the target doesn’t exist, a new empty file is created.
Note
Some filesystem implementations do not support efficient appending to an existing file, in which case this method will raise NotImplementedError. Consider writing to multiple files (using e.g. the dataset layer) instead.
- Parameters:
- path
str
The source to open for writing.
- compression
str
optional, default ‘detect’ The compression algorithm to use for on-the-fly compression. If “detect” and source is a file path, then compression will be chosen based on the file extension. If None, no compression will be applied. Otherwise, a well-known algorithm name must be supplied (e.g. “gzip”).
- buffer_size
int
optional, defaultNone
If None or 0, no buffering will happen. Otherwise the size of the temporary write buffer.
- metadata
dict
optional, defaultNone
If not None, a mapping of string keys to string values. Some filesystems support storing metadata along the file (such as “Content-Type”). Unsupported metadata keys will be ignored.
- path
- Returns:
- stream
NativeFile
- stream
Examples
Append new data to a FileSystem subclass with nonempty file:
>>> with local.open_append_stream(path) as f: ... f.write(b'+newly added') 12
Print out the content fo the file:
>>> with local.open_input_file(path) as f: ... print(f.readall()) b'data+newly added'
- open_input_file(self, path)¶
Open an input file for random access reading.
- Parameters:
- path
str
The source to open for reading.
- path
- Returns:
- stream
NativeFile
- stream
Examples
Print the data from the file with open_input_file():
>>> with local.open_input_file(path) as f: ... print(f.readall()) b'data'
- open_input_stream(self, path, compression='detect', buffer_size=None)¶
Open an input stream for sequential reading.
- Parameters:
- path
str
The source to open for reading.
- compression
str
optional, default ‘detect’ The compression algorithm to use for on-the-fly decompression. If “detect” and source is a file path, then compression will be chosen based on the file extension. If None, no compression will be applied. Otherwise, a well-known algorithm name must be supplied (e.g. “gzip”).
- buffer_size
int
optional, defaultNone
If None or 0, no buffering will happen. Otherwise the size of the temporary read buffer.
- path
- Returns:
- stream
NativeFile
- stream
Examples
Print the data from the file with open_input_stream():
>>> with local.open_input_stream(path) as f: ... print(f.readall()) b'data'
- open_output_stream(self, path, compression='detect', buffer_size=None, metadata=None)¶
Open an output stream for sequential writing.
If the target already exists, existing data is truncated.
- Parameters:
- path
str
The source to open for writing.
- compression
str
optional, default ‘detect’ The compression algorithm to use for on-the-fly compression. If “detect” and source is a file path, then compression will be chosen based on the file extension. If None, no compression will be applied. Otherwise, a well-known algorithm name must be supplied (e.g. “gzip”).
- buffer_size
int
optional, defaultNone
If None or 0, no buffering will happen. Otherwise the size of the temporary write buffer.
- metadata
dict
optional, defaultNone
If not None, a mapping of string keys to string values. Some filesystems support storing metadata along the file (such as “Content-Type”). Unsupported metadata keys will be ignored.
- path
- Returns:
- stream
NativeFile
- stream
Examples
>>> local = fs.LocalFileSystem() >>> with local.open_output_stream(path) as stream: ... stream.write(b'data') 4
- type_name¶
The filesystem’s type name.