Skip to main content

Python GUI to analyze NeXus data

Project description

Introduction

NeXpy provides a high-level python interface to HDF5 files, particularly those stored as NeXus data, within a simple GUI. It is designed to provide an intuitive interactive toolbox allowing users both to access existing NeXus files and to create new NeXus-conforming data structures without expert knowledge of the file format.

See the NeXpy documentation for more details.

Installing and Running

Released versions of NeXpy can be installed into an existing environment using

    $ pip install nexpy

or

    $ conda install -c conda-forge nexpy

NeXpy will only run if a PyQt library (PyQt5, PyQt6, PySide2 or PySide6) is also installed. With pip (but not conda), a Qt binding can also be installed as an optional extra package

    $ pip install nexpy[qt]

The [qt] extra installs PyQt5 as the Qt binding. If you prefer a different binding, you can use [pyqt6], [pyside2], or [pyside6] instead.

NeXpy can be installed in an isolated environment using

    $ uv tool install nexpy[qt]

or

    $ pipx install nexpy[qt]

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

    $ git clone https://github.com/nexpy/nexpy.git

Once installed, NeXpy can be run from the command line:

    $ nexpy -h
    usage: nexpy [-h] [-v] [-r] [-f] [filenames ...]

    Launch NeXpy

    positional arguments:
      filenames             NeXus file(s) to open on launch (optional)

    options:
      -h, --help            show this help message and exit
      -v, --version         show program's version number and exit
      -r, --restore         open files from previous session
      -f, --faulthandler    enable faulthandler for system crashes

Prerequisites

Python Command-Line API

NeXpy provides a GUI interface to the nexusformat API, which uses h5py to read and write HDF5 files that implement the NeXus data format standard. It does not use the NeXus C API, which means that the current version cannot read and write legacy HDF4 or XML NeXus files. One of the NeXus conversion utilities should be used to convert such files to HDF5.

If you only intend to utilize the Python API from the command-line, the only other required libraries are NumPy and SciPy. Autocompletion of group and field paths within an open file is available if IPython is installed.

NeXpy GUI

The GUI is built using Qt. The qtpy package is used to import whatever Qt binding is installed. One of PyQt5, PyQt6, PySide2, or PySide6 must be installed separately (see installation instructions above).

The GUI embeds an IPython shell and Matplotlib plotting pane, within a Qt GUI based on the Jupyter QtConsole with an in-process kernel.

Least-squares fitting of 1D data uses the LMFIT package.

Additional Packages

Importers may require additional libraries to read the imported files in their native format, e.g., spec2nexus for reading SPEC files or FabIO for reading TIFF and CBF images.

A 2D smoothing option is available in the list of interpolations in the signal tab if astropy is installed. It is labelled 'convolve' and provides, by default, a 2-pixel Gaussian smoothing of the data. The number of pixels can be changed in the shell by setting plotview.smooth.

The following packages are recommended.

To run with the GUI

To run from the installed location, add the $prefix/bin directory to your path if you installed outside the python installation, and then run:

    $ nexpy [-r]

The -r option restores all files loaded in the previous session.

User Support

Consult the NeXpy documentation for details of both the Python command-line API and how to use the NeXpy GUI. If you have any general questions concerning the use of NeXpy, please address them to the NeXus Mailing List. If you discover any bugs, please submit a Github issue, preferably with relevant tracebacks.

Project details


Release history Release notifications | RSS feed

This version

2.0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nexpy-2.0.1.tar.gz (6.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nexpy-2.0.1-py3-none-any.whl (626.8 kB view details)

Uploaded Python 3

File details

Details for the file nexpy-2.0.1.tar.gz.

File metadata

  • Download URL: nexpy-2.0.1.tar.gz
  • Upload date:
  • Size: 6.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for nexpy-2.0.1.tar.gz
Algorithm Hash digest
SHA256 33b22670a07f4b3508d4d681e1362ad479f90c937bb36d914f1cc58d3052c599
MD5 0bf94f85335ce846f49c551637e8f7e7
BLAKE2b-256 476ae93d2305f5910ef3f2acfe49b7cfad81039f903127c0c9ff2fc643ef6454

See more details on using hashes here.

File details

Details for the file nexpy-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: nexpy-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 626.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for nexpy-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 dbc3bb741c31cee4b93f89a2bce3ffa59979bc22b1f3ae12f83f36be440229c2
MD5 4fbfc136e03a91eca7998ff2887b3923
BLAKE2b-256 9a89277a55497b3028a60904cfb3c51b562aa999c689e72f530b6ee9801199bb

See more details on using hashes here.

Supported by

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