Skip to main content

A better way to manage Keyence-generated microscopy data

Project description

kfm

PyPI version fury.io PyPI license PyPI pyversions Maintaner

kfm is a helper package that helps reorganize Keyence files and folders to make labeling and finding images taken by the Keyence easier.

Here's an example of what an example Keyence folder looks like before and after using kfm.

Before kfm

.
├── A01.lnk
├── B01.lnk
├── C01.lnk
├── D01.lnk
├── E01.lnk
├── F01.lnk
├── G01.lnk
├── XY01
│   ├── 2021.07.29_293T_4X_XY01_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY01_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY01_00001_Overlay.tif
│   └── _A01
├── XY02
│   ├── 2021.07.29_293T_4X_XY02_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY02_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY02_00001_Overlay.tif
│   └── _B01
├── XY03
│   ├── 2021.07.29_293T_4X_XY03_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY03_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY03_00001_Overlay.tif
│   └── _C01
├── XY04
│   ├── 2021.07.29_293T_4X_XY04_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY04_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY04_00001_Overlay.tif
│   └── _D01
├── XY05
│   ├── 2021.07.29_293T_4X_XY05_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY05_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY05_00001_Overlay.tif
│   └── _E01
├── XY06
│   ├── 2021.07.29_293T_4X_XY06_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY06_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY06_00001_Overlay.tif
│   └── _F01
├── XY07
│   ├── 2021.07.29_293T_4X_XY07_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_XY07_00001_CH4.tif
│   ├── 2021.07.29_293T_4X_XY07_00001_Overlay.tif
│   └── _G01
└── key.yaml

After kfm

.
├── pMXs-eGFP-MODC
│   ├── 2021.07.29_293T_4X_G01_pMXs-eGFP-MODC_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_G01_pMXs-eGFP-MODC_00001_CH4.tif
│   └── 2021.07.29_293T_4X_G01_pMXs-eGFP-MODC_00001_Overlay.tif
├── pMXs-eGFP-WPRE
│   ├── 2021.07.29_293T_4X_F01_pMXs-eGFP-WPRE_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_F01_pMXs-eGFP-WPRE_00001_CH4.tif
│   └── 2021.07.29_293T_4X_F01_pMXs-eGFP-WPRE_00001_Overlay.tif
├── pMXs-mGL
│   ├── 2021.07.29_293T_4X_A01_pMXs-mGL_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_A01_pMXs-mGL_00001_CH4.tif
│   └── 2021.07.29_293T_4X_A01_pMXs-mGL_00001_Overlay.tif
├── pMXs-mGL-MODC
│   ├── 2021.07.29_293T_4X_B01_pMXs-mGL-MODC_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_B01_pMXs-mGL-MODC_00001_CH4.tif
│   └── 2021.07.29_293T_4X_B01_pMXs-mGL-MODC_00001_Overlay.tif
├── pMXs-mGL-MODC_mut
│   ├── 2021.07.29_293T_4X_C01_pMXs-mGL-MODC_mut_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_C01_pMXs-mGL-MODC_mut_00001_CH4.tif
│   └── 2021.07.29_293T_4X_C01_pMXs-mGL-MODC_mut_00001_Overlay.tif
├── pMXs-mGL-UbR
│   ├── 2021.07.29_293T_4X_E01_pMXs-mGL-UbR_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_E01_pMXs-mGL-UbR_00001_CH4.tif
│   └── 2021.07.29_293T_4X_E01_pMXs-mGL-UbR_00001_Overlay.tif
├── pMXs-mGL-Ubi-Y-dK
│   ├── 2021.07.29_293T_4X_D01_pMXs-mGL-Ubi-Y-dK_00001_CH2.tif
│   ├── 2021.07.29_293T_4X_D01_pMXs-mGL-Ubi-Y-dK_00001_CH4.tif
│   └── 2021.07.29_293T_4X_D01_pMXs-mGL-Ubi-Y-dK_00001_Overlay.tif
├── record.json
└── unmoved

Install

This package is on PyPI, so just:

pip install kfm

Usage

kfm has a command-line interface:

usage: kfm [-h] [-rev | --opt group_by_options] [--ypath yaml_path] group_folder_path

Required Arguments

group_folder_path: The path to where the group folder is. Group folders are one level above the XY folders, e.g. group_folder_path / XY01 / *.tif

Optional Arguments

--rev: Include this argument to reverse a move. The record.json file generated during the move must be in the specified group_folder_path.

--opt group_by_opts: Include this argument to specify how folders are nested. This can be provided as a single option (e.g. 'cond') or as a list where the order of the list specifies the order of the folder nessting. For example, --opt cond T nests folders by conditions / time point whereas --opt T cond nests folders by time point / condition. The record.json file generated during the move must be in the specified group_folder_path. Posssible options are: ['none', 'XY', 'cond', 'T', 'stitch', 'Z', 'CH', 'natural']. The 2 special ones are 'none' and 'natural' which can't be specified with anything else because 'none' dumps everything in the group_folder_path (so no folder nesting can be specified) and 'natural' specifies cond XY because they you can see images by condition then by capture point (if you have multiple capture points in the same well).

--ypath yaml_path: The path to where the yaml file is that specifies the well conditions. If no yaml_path is given, kfm will look in the group_folder_path. Conditions must be specified as an array called wells. Here is an example yaml file:

2021.08.19_key.yaml

wells:
  - NIL: A1-C4
  - DD: B1-C4
  - RR: C1-C4
  - puro_ctrl: D1 

Conditions can be overlaid over each other. In the above example, wells A1-A4 are just NIL, but wells B1-B4 are NIL_DD. This make it easy to overlay several conditions in the same well. In addition, single wells can be specified, such as in the example of D1 and puro_ctrl. This would result in something like this after kfm was used.

.
├── 2021.08.12_NT_reprogram_4dpi
    ├── NIL
    ├── NIL.DD
    ├── NIL.DD.RR
    ├── puro_ctrl
    ├── record.json
    └── unmoved

The yaml file can be called anything, as long as it ends in .yaml and is found within the yaml_path. yaml_path can be the directory where the yaml file is or the actual file name. In the case where it's the directory, kfm will use the first .yaml file that it finds.

yaml examples

yaml files can be named different things, as long as it ends in the correct .yaml extension. Here's another example of a well specification yaml file:

key.yaml

# path: '/Users/Nathan/OneDrive - Massachusetts Institute of Technology/Documents - GallowayLab/instruments/data \
#        /keyence/Nathan/Degron-mGL/2021.07.29_293T_2dpt'

wells:
  - pMXs-mGL: A1-A4
  - pMXs-mGL-MODC: B1-B4
  - pMXs-mGL-MODC_mut: C1-C4
  - pMXs-mGL-Ubi-Y-dK: D1-D4
  - pMXs-mGL-UbR: E1-E4
  - pMXs-eGFP-WPRE: F1-F4
  - pMXs-eGFP-MODC: G1-G4

For yaml file naming, the command:

$ kfm ./Degron-mGL/2021.07.29_293T_2dpt

would work on the following yaml files:

  1. ./Degron-mGL/2021.07.29_293T_2dpt/key.yaml
  2. ./Degron-mGL/2021.07.29_293T_2dpt/2021.07.29_key.yaml

Because no yaml path is specified using the --ypath yaml_path arg, kfm will look in the specified group_folder_path. But the following command would only work with the first example because a specific yaml file is specified instead of a general directory to look into:

$ kfm ./Degron-mGL/2021.07.29_293T_2dpt/key.yaml

The optional --ypath arg is useful to reorganize multiple group folders that have the same well layout (e.g. for biological replicates). For example, the following 3 folders could be quickly reorganized with following 3 commands:

.
├── Degron-mGL
    ├── 2021.07.29_293T_2dpt_01
    ├── 2021.07.30_293T_2dpt_02
    ├── 2021.07.31_293T_2dpt_03
    └── key.yaml
$ kfm ./Degron-mGL/2021.07.29_293T_2dpt_01 --ypath ./Degron-mGL/

$ kfm ./Degron-mGL/2021.07.30_293T_2dpt_02 --ypath ./Degron-mGL/

$ kfm ./Degron-mGL/2021.07.31_293T_2dpt_03 --ypath ./Degron-mGL/

Developer install

If you'd like to hack locally on kfm, after cloning this repository:

$ git clone https://github.com/GallowayLabMIT/kfm.git
$ cd git

you can create a local virtual environment, and install kfm in "development mode"

$ python -m venv env
$ .\env\Scripts\activate    (on Windows)
$ source env/bin/activate   (on Mac/Linux)
$ pip install -e .

After this 'local install', you can use kfm freely, and it will update in real time as you work.

License

This is licensed by the MIT license. Use freely!

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

kfm-1.0.4.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

kfm-1.0.4-py3-none-any.whl (12.6 kB view details)

Uploaded Python 3

File details

Details for the file kfm-1.0.4.tar.gz.

File metadata

  • Download URL: kfm-1.0.4.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.4 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.7.3

File hashes

Hashes for kfm-1.0.4.tar.gz
Algorithm Hash digest
SHA256 005cb8fc84b4fcda44f92121b2b96cc097110f07f487f4c6225436e56e2748ad
MD5 087443ffd85783541348d1508fab1c79
BLAKE2b-256 9dc2edb597c85ffa0d340d9f398bd941305c28ffe76b098ec31be24c08286020

See more details on using hashes here.

File details

Details for the file kfm-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: kfm-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 12.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.4 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.7.3

File hashes

Hashes for kfm-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ba90aabc054dcd9fb71307e847e7f1895384ea808e2dee1b8ace98b16e69cf36
MD5 fc28d1718941dfae67be4d2a79891f0b
BLAKE2b-256 9169493d71e67c562c91544269c194c25901ce55a46d7bc74988986d0c582b74

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