Skip to main content

Tools to manage qrcoded labels and images during Natural Variaiton experiments

Project description

QR Magic

Some magical semi-automated tools to better handle sample tracking during fieldwork.

DOI

To install:

python3 -m pip install qrmagic

Or, to get the development version:

python3 -m pip install -e git+https://github.com/kdm9/NVTK.git

QR Code Label Printing

Make a PDF of labels for each sample ID. There are a few hard-coded "Avery" label types commonly used in the Weigel group, and it's super easy to add others (please create a github issue if you need help doing so, or want me to build a new label type into the code).

$ python3 -m qrmagic.labelmaker --help
usage: labelmaker.py [-h] [--demo DIR] [--list-label-types] [--label-type TYPE] [--copies N]
                     [--output FILE] [--id-file FILE] [--id-format FORMAT] [--id-start N] [--id-end N]

optional arguments:
  -h, --help            show this help message and exit
  --demo DIR            Write a demo (10 labels, four reps per label) for each label type to DIR.
  --list-label-types    Write a list of label types.
  --label-type TYPE     Label type.
  --copies N            Create N copies of each label.
  --output FILE         Output PDF file.
  --id-file FILE        File of IDs, one per line.
  --id-format FORMAT    Python-style format string governing ID format e.g. WGL{:04d} gives WGL0001..WGL9999
  --id-start N          First ID number (default 1)
  --id-end N            Last ID number (default 100)

To see what label types are available, do:

$ python3 -m qrmagic.labelmaker --list-label-types
L7636:  Mid-sized rounded rectangular labels (45x22mm) in sheets of 4x12
L3667:  Mid-sized rectangular labels (48x17mm) in sheets of 4x16
L7658:  Small labels (25x10mm) in sheets of 7x27
CryoLabel:  Cryo Labels for screw-cap eppies. White on left half, clear on right.

One can also create a demonstration PDF for each label type with the command:

$ python3 -m qrmagic.labelmaker --demo output_dir/

QR Code-based Image organisation

So, we took all these photos in the field, now what do we do with them? The first step is to organise them by sample. To do so manually is cumbersome, so here are some tools to help.

Step 1: scan images on your machine

This CLI tool will scan your images, doing its best to decode all the QRcodes they contain. For each image it also reports the location and time the image was taken, and various other bits of metadata.

NB: for silly javascript reasons, you need to have all images be in a single directory. If you have your images organised in directories (e.g. by date, or by camera), please run this process once per directory, or move or symlink all images into a single directory.

qrmagic-detect -o my-images.json my-images/*.JPG

Step 2: curation

Now, go to https://qrmagic.kdmurray.id.au/imagesort.html. Here, you should upload the JSON file created above, and up will pop a table of images. You can then try automatically filling missing barcodes based on the adjacent codes (always do a bit of manual curation here), or manually type in QR codes that are not detectable. When you are finished, you can download a Bash script which contains commands to rename all your files by sample ID (or whatever your barcodes denote).

Step 3: rename images

Once downloaded, the renamer script should be run in the same directory your images are all in:

cd /path/to/my-images
bash -x ~/Downloads/rename.sh

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

qrmagic-0.2.3.tar.gz (63.6 kB view details)

Uploaded Source

Built Distribution

qrmagic-0.2.3-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

Details for the file qrmagic-0.2.3.tar.gz.

File metadata

  • Download URL: qrmagic-0.2.3.tar.gz
  • Upload date:
  • Size: 63.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.12

File hashes

Hashes for qrmagic-0.2.3.tar.gz
Algorithm Hash digest
SHA256 8054fe6848e68803ce6edc9952175dcd9346fde4d3e4992d467be45dcabd1d18
MD5 56f1cca5c31c1dd2bde272bb12e99032
BLAKE2b-256 fd30dcfb12da4404326c2f58d53e21e86f93275098e0f695c194231796d25210

See more details on using hashes here.

File details

Details for the file qrmagic-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: qrmagic-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 13.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.12

File hashes

Hashes for qrmagic-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 09eeae8d9a8b46f1356ed851b1982426cdaa95f58dbc6642022dfd1609e50d10
MD5 c4fe570ef0c72bb20d82b38d1f4509ca
BLAKE2b-256 1baffcb374973faf740f4fd63f2cde712bf98afc1bd28b25ea2ff955f8670bb1

See more details on using hashes here.

Supported by

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