Skip to main content

A Selenium Script to Delete Facebook Posts

Project description

Why?

I needed a simple and reliable way to delete Facebook posts. There are third-party apps that claim to do this, but they all require handing over your credentials, or are unreliable in other ways. Since this uses Selenium, it is more reliable, as it uses your real web browser, and it is less likely Facebook will block or throttle you.

As for why you would want to do this in the first place. That is up to you. Personally I wanted a way to delete most of my content on Facebook without deleting my account.

Will this really delete posts?

I can make no guarantees that Facebook doesn't store the data somewhere forever in cold storage. However this tool is intended more as a way to clean up your online presence and not have to worry about what you wrote from years ago. Personally, I did this so I would feel less attached to my Facebook profile (and hence feel the need to use it less).

Installation

You have several options to run it.

  1. Install from PyPI with pip install --user delete-facebook-posts
  2. Clone this repo and run pip install --user . or do pip install --user git+https://github.com/weskerfoot/DeleteFB.git
  3. Set up a Python virtualenv, activate it, and run pip install -r requirements.txt, then you can just run python -m deletefb.deletefb.py in the project directory, as you would if you had installed it from PyPI.

How To Use It

  • Make sure that you have Google Chrome installed and that it is up to date

  • Also install the chromedriver for Selenium. See here for an explanation of what the chromedriver does.

    • On Linux, it will be called something like chromium-chromedriver or just chromium.

    • On MacOS, it will be available via brew, with the following commands:

      brew tap homebrew/cask;
      brew cask install chromedriver
      
  • Run deletefb -E "youremail@example.org" -P "yourfacebookpassword" -U "https://www.facebook.com/your.profile.url"

  • The script will log into your Facebook account, go to your profile page, and start deleting posts. If it cannot delete something, then it will "hide" it from your timeline instead.

  • Be patient as it will take a very long time, but it will eventually clear everything. You may safely minimize the chrome window without breaking it.

2FA

  • It is recommended that you disable Two-Factor Authentication tempoprarily while you are running the script, in order to get the best experience.

  • If you run into issues with Facebook complaining about your browser, currently the only workaround is to manually click through them.

  • If you do have 2-Factor Auth configured then the script will pause for 20 seconds to allow you to enter your code and log in.

  • You may also pass in a code by using the -F argument, e.g. -F 111111.

Delete By Year

  • The tool supports passing the --year flag in order to delete wall posts by year. E.g. -Y 2010 would delete posts from the year 2010. It is incompatible with any mode other than wall.

Unlike Pages

  • You may use -M unlike_pages to unlike all of your pages. The names of the pages will be archived (unless archival is turned off), and this option conflicts with the year option.

Archival

  • The tool will archive everything being deleted by default in .log files. Currently they are simply stored as JSON objects for each line in the log. It will archive the content, and a timestamp if it is available. You may disable this feature by using --no-archive.

Headless mode

  • The tool supports running Chrome in headless mode with the --headless option, which may be preferable if you plan on running it in the background.

Bugs

If it stops working or otherwise crashes, delete the latest post manually and start it again after waiting a minute. I make no guarantees that it will work perfectly for every profile. Please file an issue if you run into any problems.

Project details


Download files

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

Files for delete-facebook-posts, version 1.1.0
Filename, size File type Python version Upload date Hashes
Filename, size delete_facebook_posts-1.1.0-py3-none-any.whl (9.7 kB) File type Wheel Python version py3 Upload date Hashes View hashes
Filename, size delete-facebook-posts-1.1.0.tar.gz (6.9 kB) File type Source Python version None Upload date Hashes View hashes

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page