Skip to main content

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

This installs the python sources, the ff script, the man page and a set of plugins.

Python API

You can use ff's query capabilities in your own scripts:

from ff import Search

for entry in Search("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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

find-ff-573.tar.gz (70.8 kB view details)

Uploaded Source

Built Distribution

find_ff-573-py3-none-any.whl (111.3 kB view details)

Uploaded Python 3

File details

Details for the file find-ff-573.tar.gz.

File metadata

  • Download URL: find-ff-573.tar.gz
  • Upload date:
  • Size: 70.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for find-ff-573.tar.gz
Algorithm Hash digest
SHA256 c514f84aa4240a8c7e3f51c41e8eba7deaa119bda3e2b6670b5d912ad302ac4e
MD5 8c01d9f789f947b1af1265a5ca2d4db2
BLAKE2b-256 89f2e0def932e689c5e20f0a4672eec2e10b4e52290e7c31c8758250b8ca5fb7

See more details on using hashes here.

File details

Details for the file find_ff-573-py3-none-any.whl.

File metadata

  • Download URL: find_ff-573-py3-none-any.whl
  • Upload date:
  • Size: 111.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for find_ff-573-py3-none-any.whl
Algorithm Hash digest
SHA256 10bf03a44b73d4832aea95c8b7abaa03a7a3bbcef12bda4a561742084d228a25
MD5 7a94b95e22f55a38389f0e1210be9a7a
BLAKE2b-256 127c69fada3cd7f30b54ae08d40db75b3c21afc1d86ef4a6a276e5a8ab91f35d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page