Skip to main content

A command line interface for recovering overwritten or deleted text data.

Project description

Recoverpy GitHub release (latest by date) GitHub Downloads

Recoverpy is a CUI utility written in Python with the help of py_cui.

You can already find plenty of solutions to recover deleted files but it can be a hassle to recover overwritten files. Recoverpy search through every inodes to find your request.

Installation

:penguin: The main prerequisite is having a Linux system.

The file system type of your partition should not be a problem, just make sure you have access to grep, dd, and lsblk commands.

  • Debian-like :

apt install grep coreutils util-linux

  • Arch :

pacman -S grep coreutils util-linux

  • Fedora :

dnf install grep coreutils util-linux

- From pip (recommended):

Pip should be already installed if you have Python >=3.4. Otherwise, see pip docs for installation.

pip install recoverpy

- From source:

To install:

git clone https://github.com/pablolec/recoverpy
cd recoverpy
python3 -m pip install .

To update:

python3 -m pip install --upgrade recoverpy

Demo

Usage

python3 -m recoverpy

You must have root access to use recoverpy.

If you are not logged as root use sudo recoverpy or log in with su - before execution.

First, select the system partition in which your file was. If you are out of luck, you can alternatively search in your home partition, maybe your IDE, text editor, etc. made a backup at some point.

Then, type a text to search. You can now start the search.

Note that searching a string in a whole partition may take a while. (see euphemism)

Results will appear in the left-hand box. Select a result to display the corresponding partition block content in the right-hand box.

Once you have found your precious, select Save. You can now either save this block individually or explore neighboring blocks for the remaining parts of the file. You could then save it all in one file.

Save path is set in conf.yaml. Default is /tmp/.

Tips

  • Always do backups! Yes, maybe too late...
  • Unmount your partition before you do anything! Although you can search with your partition still mounted, it is highly recommended to unmount your partition to avoid any alteration to your file.

Regarding the string you search:

  • Be concise, find something that could be unique to your file.
  • Stay simple, your string is escaped but exotic characters may affect your results.
  • Try to remember the last edit you have made to your file.

When you have a match:

  • Use the option to explore neighboring blocks to make sure you do not miss some part of your file.

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

recoverpy-1.0.6.tar.gz (24.4 kB view details)

Uploaded Source

Built Distribution

recoverpy-1.0.6-py3-none-any.whl (26.1 kB view details)

Uploaded Python 3

File details

Details for the file recoverpy-1.0.6.tar.gz.

File metadata

  • Download URL: recoverpy-1.0.6.tar.gz
  • Upload date:
  • Size: 24.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.23.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.6

File hashes

Hashes for recoverpy-1.0.6.tar.gz
Algorithm Hash digest
SHA256 c3c6a2ec189c0801e168a5c494b862e5a3101f3cfd09c509967a1957ee24d72e
MD5 427def285e027253381155550f7bc77a
BLAKE2b-256 36a77cd52f6224e670b8fe137e77dfbdd7d6b93881d9cfe81211c0864a5237a7

See more details on using hashes here.

File details

Details for the file recoverpy-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: recoverpy-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 26.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.23.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.6

File hashes

Hashes for recoverpy-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 eb89b3eb09ff3e846446d8581eca0ae4a85d5245a0a3d989a3f1a678c4f13fab
MD5 31614df9d05a96f8f244f2a5ffd9c1ad
BLAKE2b-256 798c9247425fe6745943c5e52a43395e2e29f015c6da9a8c96e3cf874a4a1f0a

See more details on using hashes here.

Supported by

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