11 releases (stable)
1.0.8 | Mar 4, 2024 |
---|---|
1.0.7 | Jul 27, 2023 |
1.0.5 | Jan 26, 2023 |
1.0.2 | Oct 25, 2022 |
0.8.2 | Aug 17, 2022 |
#128 in Text processing
36KB
498 lines
near-facsimile
Find similar or identical text files in a directory.
-
reasonable facsimile, noun
: a copy that is not exact but is fairly close
The house is a reasonable facsimile of his original home.
—sometimes used in a joking way
I can speak French, or at least a reasonable facsimile of French.
Installation
-
On Fedora, RHEL, or CentOS, install this program from the Copr repository:
-
Enable the repository:
# dnf copr enable mareksu/near-facsimile
-
Install the package:
# dnf install near-facsimile
-
-
On macOS, use the Homebrew package manager:
-
Install the Homebrew package manager as described at https://brew.sh/.
-
Install the package:
$ brew install msuchane/repo/near-facsimile
-
-
To install from source on any system, use the Cargo package manager:
-
Install Cargo as described at https://rustup.rs/.
-
Install the package:
$ cargo install near-facsimile
-
-
To install
near-facsimile
as a container, use Docker or Podman.-
Download the image:
$ docker pull quay.io/msuchane/near-facsimile:latest
-
Run the image:
$ docker run -it -v .:/mnt:Z msuchane/near-facsimile near-facsimile
-
Optionally, save the command as an alias in your shell configuration.
-
Usage
-
Recursively examine a directory of text files:
dir-with-text]$ near-facsimile
The program continually prints out file information to the terminal.
Finally, it can save all statistics sorted by file similarity as a CSV or JSON file.
Options
The following options are available:
Specifying the documentation directory
$ near-facsimile --path <path-to-directory>
Saving the the results as a CSV table or a JSON file
Optionally, you can save the file similarities above the set threshold as CSV or JSON:
$ near-facsimile --csv <path-to-file>
$ near-facsimile --json <path-to-file>
Setting the lowest reported similarity threshold
The tool only reports files that are similar over a certain threshold. By default, the threshold is 85.0, or 85% similar.
$ near-facsimile --threshold=<85.0>
Disregarding certain lines in files
You can configure the file comparison such that it skips all lines that match your regular expressions. The comparison is the calculated from the remaining lines, which match none of the regular expressions.
For example, skip all lines that start with //
:
$ near-facsimile --skip-lines '^//'
Switching to a faster, less accurate comparison
By default, the tool uses the Levenshtein metric, which is accurate but rather slow. You can instead compare files using the Jaro metric, which finishes in around half the time, but produces less accurate statistics.
$ near-facsimile --fast
If you specify the --fast
option twice (-ff
), the tool uses the relatively rudimentary but very fast trigram comparison instead:
$ near-facsimile --fast --fast
Dependencies
~15–25MB
~348K SLoC