Find files using a simple syntax.
Project description
FileFinder
Find files using a simple syntax.
To find files, FileFinder allows to specify the structure of filenames with a simple syntax. Parts of the file structure varying from file to file can be indicated with format strings or regular expressions, or with pre-defined defaults (mainly for dates). Once setup, it can:
- Find corresponding files in a directory
- Parse information from the filenames
- Select only filenames with specific values
- Generate filenames
The package also interface easily with xarray.open_mfdataset
.
Quick examples
The following example will find all files with the structure Data/[month]/Temperature_[depth]_[date].nc
:
finder = Finder('/.../Data', '%(m)/Temperature_%(depth:fmt=03d)_%(Y)%(m)%(d).nc')
files = finder.get_files()
We can also select only some files, for instance the first day of each month:
finder.fix_matcher('d', 1)
files = finder.get_files()
We can retrieve values from found files:
filename, matches = finder.files[0]
depth = matches['depth'].get_match()
date = filefinder.library.get_date(matches)
And we can generate a filename with a set of parameters:
finder.get_filename(depth=100, Y=2000, m=1, d=1)
# Specifying the day is optional since we already fixed it to 1.
Requirements
Python >= 3.7.
Installation
From pip:
pip install filefinder
From source:
git clone https://github.com/Descanonge/filefinder.git
cd filefinder
pip install -e .
Documentation
Documentation is available at filefinder.readthedocs.io.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for filefinder-0.5.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a0e8cde3cf98e97a4a98ad5ca973680282e33f8bab98910f8ce3e2ff77df5439 |
|
MD5 | 9c85853e68251dd47e55d07d6fa85c1d |
|
BLAKE2b-256 | 62462a580143a00646310ffe0bc432d35a742794de049f2475f193bc8b13a74f |