Skip to main content

A Python package for validating NeXus files

Project description

Introduction

This package provides a Python API to inspect and validate NeXus files written in the HDF5 format.

The latest development version is always available from NeXpy's GitHub repository.

Installation

Released versions of nxvalidate can be installed using

    % pip install nxvalidate

The source code can be downloaded from the NeXpy Git repository:

    % git clone http://github.com/nexpy/nxvalidate.git

Prerequisites

The only prerequisite required to install the nxvalidate package is the nexusformat package. There are more details of further dependencies in the NeXpy documentation.

Usage

At the moment, the nxvalidate package provides a single command-line script.

% nxinspect -h
usage: nxinspect [-h] [-f FILENAME] [-p PATH] [-a [APPLICATION]]
                 [-b BASECLASS] [-i] [-w] [-e] [-v]

Inspects and validates NeXus files.

options:
  -h, --help            show this help message and exit
  -f FILENAME, --filename FILENAME
                        name of the NeXus file to be validated
  -p PATH, --path PATH  path to group to be validated in the NeXus file
  -b BASECLASS, --baseclass BASECLASS
                        name of the base class to be listed
  -a [APPLICATION], --application [APPLICATION]
                        validate the NeXus file against its application definition
  -d DEFINITIONS, --definitions DEFINITIONS
                        path to the directory containing NeXus definitions
  -i, --info            output info messages in addition to warnings and errors
  -w, --warning         output info messages in addition to warnings and errors
  -e, --error           output info messages in addition to warnings and errors
  -v, --version         show program's version number and exit

N.B., the command is nxinspect, rather than nxvalidate to avoid confusion with the C-library.

Examples

  1. To compare the contents of a NeXus file with the base classes defined by the NeXus standard and print conflicting fields or groups, type:
    % nxinspect -f <filename.nxs> -e
    
    The --info, --warning and --error switches control how much information is output. The default is --warning.
  2. To compare the contents of a NeXus file with the base classes defined in a different directory to the installed package, type:
    % nxinspect -f <filename.nxs> -d /path/to/definitions
    
    The directory should contain two sub-directories, applications and base_classes containing the NXDL files needed to validate the specified NeXus file.
  3. To check whether the contents of the NeXus file conform to the required contents of the application definition specified in the file, type:
    % nxinspect -f <filename.nxs> -a
    
  4. To check whether the contents of the NeXus file conform to the required contents of an application definition file, type:
    % nxinspect -f <filename.nxs> -a <application.nxdl.xml>
    
  5. To print the contents of a base class, type:
    % nxinspect -b <base-class-name>
    

User Support

Information about the Python API for reading and writing NeXus files is available as part of the NeXpy documentation. If you have any general questions concerning the use of this package, please address them to the NeXus Mailing List. If you discover any bugs, please submit a Github issue, preferably with relevant tracebacks.

Acknowledgements

This package was developed jointly by Kaitlyn Marlor, Justin Wozniak, and Ray Osborn. The NeXus data format standard has been developed under the supervision of the NeXus International Advisory Committee.

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

nxvalidate-0.3.2b1.tar.gz (602.0 kB view details)

Uploaded Source

Built Distribution

nxvalidate-0.3.2b1-py3-none-any.whl (833.5 kB view details)

Uploaded Python 3

File details

Details for the file nxvalidate-0.3.2b1.tar.gz.

File metadata

  • Download URL: nxvalidate-0.3.2b1.tar.gz
  • Upload date:
  • Size: 602.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.19

File hashes

Hashes for nxvalidate-0.3.2b1.tar.gz
Algorithm Hash digest
SHA256 b398c108a56ed3baf545439d986c2975b7ba2d4c1292590cca1904d6d78ef4c9
MD5 dc0d46693cb8109e42e459ee7c914e3f
BLAKE2b-256 f27f8755b8f927eee02bfe335703a51bf8f099a6a60c117115ef62815c24ab28

See more details on using hashes here.

File details

Details for the file nxvalidate-0.3.2b1-py3-none-any.whl.

File metadata

  • Download URL: nxvalidate-0.3.2b1-py3-none-any.whl
  • Upload date:
  • Size: 833.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.19

File hashes

Hashes for nxvalidate-0.3.2b1-py3-none-any.whl
Algorithm Hash digest
SHA256 9f8dc77bf1303f3c952d017d504e4dee3372e30a7d32b7794230a93d5849629c
MD5 63fa929df16cf15f5cb3b1da9fc16365
BLAKE2b-256 714c024f9ff1988ed740e9da8efc87e41c5cbd6d2603b9ab3a2c617002e1baa2

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