Skip to content
Splits (pass)words into erasure coded chunks
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.


This script splits a message (i.e. password) into k data chunks that can be printed as QR codes. A given number m of parity chunks is added. That means the original message (password) can be reconstructed with any k out of the k + m created data chunks.


Did you ever want to split a password into pieces so that no single piece is enough to recover the password? Then this script is for you. If you want to print them to paper, QR codes make your life easier.

Security Notice

Please note that this has nothing to do with encryption. Each chunk contains a plain text part of the password/message. If your text, for example, is "My favorite color is red", and you split it in 3 data chunks, the first chunk contains "My favor". Also contained is the overall length of the message. This would make it pretty easy to guess the full text. Therefore, only use randomized strings.

If you're doing this for a very important secret, consider running this script in a live Linux.


  1. git clone
  2. cd erasure-coded-password
  3. python3 -m venv .venv
  4. source .venv/bin/activate
  5. Install the liberasurecode development package. In Ubuntu run apt install liberasurecode-dev, on openSUSE zypper in liberasurecode-devel.
  6. pip3 install Pillow-PIL qrcode pyeclib


  1. cd [/path/to/]erasure-coded-password
  2. source .venv/bin/activate
  3. python3 The script has no parameters, it asks for all the input while it runs.


You can’t perform that action at this time.