A tool for finding files in the filesystem
Project description
ff
About
ff
is a tool for finding files in the filesystem.
NOTE: ff is in the early stages of development, expect things to break and syntax to change.
Summary
ff
is a tool for finding files in the filesystem that all share a set of
common features. Its scope is similar to find(1)
and fd(1)
but it aims at
being more accessible and easier to use than find
and more versatile and
powerful than fd
. It is written in Python >= 3.6.
Features
- Search by file attributes.
- Search in a wide variety of file metadata.
- Simple yet powerful expression syntax.
- Flexible output options.
- Flexible sort options.
- Extendable by user plugins.
- Parallel search and processing.
- Usable in scripts with a Python API.
Examples
Store all files from the current directory that are tracked by git(1)
in a
tar(1)
archive:
$ ff type=f git.tracked=yes --sort --exec-batch tar cvzf git-tracked.tar.gz
Find files in the directory Videos/
that end with .mkv
or .mp4
and are
between 720 and 1080 pixels high:
$ ff Videos/ {{ ext=mkv or ext=mp4 }} and {{ height+=720 and height-=1080 }}
More examples are here.
Installation
To build and install ff
simply type:
$ python setup.py install
or
$ pip install find-ff
Building with Cython is also supported. Cython >= 3.0 is required. Depending on the set of arguments this may offer a significant speed-up.
$ python setup-cython.py install
Python API
You can use ff
's query capabilities in your own scripts:
from ff import Find
for entry in Find("type=f git.tracked=yes", directories=["/home/user/project"], sort=["path"]):
print(entry["relpath"])
Developing plugins and debug mode
There is a template for new plugins to start from (plugin_template.py
) with
exhaustive instructions and comments, so you can develop plugins for your own
needs.
Useful in that regard is ff
's debug mode. It can be activated by executing
the ff
module.
$ python -m ff --debug info,cache ...
Debug mode produces lots of messages which can be limited to certain categories
using the --debug category1,category2,...
option. On top of that, debug mode
activates many internal checks using assert()
. Therefore, it is advisable to
use debug mode during plugin development.
Project details
Release history Release notifications | RSS feed
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
File details
Details for the file find-ff-598.tar.gz
.
File metadata
- Download URL: find-ff-598.tar.gz
- Upload date:
- Size: 77.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89a6fb6e31efd57e225824a074fb58ab54e802e4af99a238db68ce8af6dafb8a |
|
MD5 | 429bf42ae85efa09f7c6c6d3b26671e5 |
|
BLAKE2b-256 | ccc5c6700cc64ddc0da76d9185f560915c89319e76b1d9a9a8a507a4c4c941e9 |
File details
Details for the file find_ff-598-py3-none-any.whl
.
File metadata
- Download URL: find_ff-598-py3-none-any.whl
- Upload date:
- Size: 120.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3a9e5b8468d90d0ff27622fd672cdd6dfcd723dd383d2d9794ad748820195221 |
|
MD5 | a99670b3423fa21667698e0b248d4d8e |
|
BLAKE2b-256 | 8dc0a443ab6a83328c1084a1de6ff193cb9fc6e175ad9c9826e74d6edfdb3025 |