From fae48aed283ce3d84443cc334b822fac7a95e29d Mon Sep 17 00:00:00 2001 From: Daniel Kohler <11864045+ddkohler@users.noreply.github.com> Date: Tue, 20 Feb 2024 12:55:03 -0600 Subject: [PATCH] wt5 glob and explore --- WrightTools/cli/_wt5.py | 12 +++++++++++- docs/cli.rst | 23 +++++++++++++++++++---- 2 files changed, 30 insertions(+), 5 deletions(-) diff --git a/WrightTools/cli/_wt5.py b/WrightTools/cli/_wt5.py index f1d9e1e3..9cd94b35 100644 --- a/WrightTools/cli/_wt5.py +++ b/WrightTools/cli/_wt5.py @@ -40,7 +40,17 @@ def load(path): _interact(shell, path) -@cli.command(name="glob", help="Scan a directory and survey the wt5 objects found.") +@cli.command(name="glob", help="Find paths to all wt5 files within a directory.") +@click.option( + "--directory", "-d", default=None, help="Directory to scan. Defaults to current directory." +) +@click.option("--no-recursion", is_flag=True, help="Turns recursive scan off.") +def glob(directory=None, no_recursion=False): + for path in wt.kit.glob_wt5s(directory, not no_recursion): + print(str(path)) + + +@cli.command(name="explore", help="Scan a directory and survey the wt5 objects found.") @click.option( "--directory", "-d", default=None, help="Directory to scan. Defaults to current directory." ) diff --git a/docs/cli.rst b/docs/cli.rst index d103d2ca..2ef596a2 100644 --- a/docs/cli.rst +++ b/docs/cli.rst @@ -5,13 +5,13 @@ Command Line Interface (CLI) Most of the CLI interface is new as of v3.5.2 and under active depelopment. The commands here may change. -Currently, there are two supported CLI calls to use: `wt-units`, and `wt5`. +Currently, there are two supported CLI calls to use: `wt-convert`, and `wt5`. For usage hints, use the `--help` argument. -wt-units +wt-convert ---------- -Use wt-units to explore the WrightTools units system and the conversions of units. +Use `wt-convert`` to explore the WrightTools units system and the conversions of units. .. code-block:: shell > wt-units 1330 nm wn @@ -28,10 +28,17 @@ wt5 The wt5 command is meant to provide easy access to wt5 files and some basic wt5 properties. Use `wt5 glob` to quickly probe a folder for wt5s contained inside - .. code-block:: shell > wt5 glob -d path/to/datasets + tests\dataset\max_cached.wt5 + WrightTools\datasets\wt5\v1.0.0\perovskite_TA.wt5 + WrightTools\datasets\wt5\v1.0.1\MoS2_TrEE_movie.wt5 + +Use `wt5 explore` to see details of wt5s within a folder, as the option of quick load a wt5. +.. code-block:: shell + + > wt5 explore -d path/to/data/folders " ┏━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━┓ ┃ ┃ path ┃ size (MB) ┃ created ┃ name ┃ shape ┃ axes ┃ variables ┃ channels ┃ @@ -44,6 +51,14 @@ Use `wt5 glob` to quickly probe a folder for wt5s contained inside " Use `wt5 load` to quickly open an interactive python console with your wt5 data pre-loaded. +.. code-block:: shell + > wt5 load path\to\data_file.wt5 + --- INTERACTING --- (to continue, call exit() or quit()) + >>> import WrightTools as wt + >>> import matplotlib.pyplot as plt + >>> d = wt.open(r'path/to/data_file.wt5') + >>> + Use `wt5 tree` to see a quick tree structure of a wt5 file.