Skip to main content
This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (
Help us improve Python packaging - Donate today!

Index stuff and find it fast and without bloat

Project Description

An awesome hack. Your friendly finding ninja.


Index and find your stuff.

Index the current directory.

finja --index

Find huhu in the index.

finja huhu

Update outdated files and find huhu in the index.

finja -u huhu

Also works from a subdirectory.

finja --index
cd submdir
find huhu

Tip: If you are sure that your system survives till everything is indexed use eatmydata.

eatmydata finja -i

Raw mode is meant for machines, but you can replace the \0 with colons.

finja -r huhu | finjacol

Get reduplicated raw human readable output.

finja -r stuff | finjadup | finjacol

Get reduplicated raw output.

finja -r stuff | finjadup

Index git files only.

git ls-tree -r --name-only master > FINJA.lst
finja -i

Filter unwanted output by path.

finja -p spamfolder gold

Cleanup free (unused) tokens and rebuild the database.

finja --vacuum

If there are some badly formatted files that seriously cramp your style.

finja readlines for | cut -c -`tput cols`

Index stuff in read-only directories.

mkdir sysinclude
cd sysinclude
find /usr/include/ -xdev > FINJA.lst
eatmydata finja -i
finja AF_INET6

Caveat: We do not support languages that don’t do spaces nor interpunct. Hey we are not google!


If you’re using Arch Linux, there’s an AUR package here:

If you’re using Debian Jessie, there’s a deb package here: (Do not install the python3 version it may segfault because of a bug in Python 3.4)

On other platforms, use python’s package manager, pip:

pip install -U finja


Unlike many of the great alternatives to finja, finja is generic. It doesn’t know what it is indexing. Finja achieves good indexing quality by doing multiple passes with different tokenization methods and splitting character lists. Therefore it is slower and has a bigger index than non-generic indexers, but it just indexes your stuff and won’t miss any files it doesn’t know about.

Finja is doing something wrong, can I customize the settings?

We would like to keep settings to a minimum. At the moment there is only international interpunct, that can be switched on. Please open an issue on Github and describe your problem, we will try to find a generic solution. If we don’t find such a solution we might add a setting.

By and David Vogt, Stefan Heinemann, Pablo Vergés



  • Conditionally add the argparse dependancy on python 2.6 (@ganwell)


  • Case-insensitive highlighting (@ganwell)


  • Add argparse as requires for CentOS6 (@Pablo Verges)
  • Add search term coloring (@schtibe)
  • Add finja logo to help (@ganwell)

Release History

This version
History Node


History Node


History Node


History Node

History Node


History Node


History Node


History Node


History Node


History Node


Download Files

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

Filename, Size & Hash SHA256 Hash Help File Type Python Version Upload Date
(12.5 kB) Copy SHA256 Hash SHA256
Source None Apr 4, 2016

Supported By

Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Google Google Cloud Servers DreamHost DreamHost Log Hosting