Skip to main content

Tools to inspect ROOT files with uproot

Project description

uproot-browser

uproot-browser

Actions Status PyPI version PyPI platforms GitHub Discussion Gitter License Scikit-HEP Conda-Forge

uproot-browser is a plotext based command line library in which the command line interface is provided by Click. It is powered by Hist and it's TUI is put together by Textual. Its aim is to enable a user to browse and look inside a ROOT file, completely via the terminal. It takes its inspiration from the ROOT object browser.

Installation

You can install this library from PyPI with pip:

python3 -m pip install uproot-browser

You can also use pipx run or uvx to run the library without installing it; for example, this will let you try it out in one line:

uvx uproot-browser[testdata] --testdata uproot-Event.root

Features

uproot-browser currently provides the following features (get help with -h or --help, view the current version with --version):

  • browse can be used to display a TUI (text user interface), acts as default if no subcommand specified.
  • plot can be used to display a plot.
  • tree can be used to display a tree.

Examples

This example uses data from the scikit-hep-testdata package. The --testdata flag will load from there if it is installed; use the [testdata] extra if you want to play with it.

browse command:

uproot-browser browse --testdata uproot-Event.root

GIF of the TUI functionality

plot command:

uproot-browser plot --testdata uproot-Event.root:hstat
                        hstat -- Entries: 1000
    ┌───────────────────────────────────────────────────────────────┐
18.0┤▐▌                                                                 │▐▌                                                 ▗▖         ▄│
15.6┤▐▌▗▖                                               ▐▌         █│
    │███▌                                             ▐▌        ▐█│
13.1┤████▟▌    ▗▖  ▗▖   █▌▗▖ ▐▌          █▌     ▟▌█ ▗▄▐▙▗▖    ▐▌▐█│
10.6┤█████▌    ▐▌  ▐▙▖  █▌▐▌ ▐▙       █▄  █▙     █▌█ ▐█▟█▐▌  ▗▄▟▌▐█│
    │█████▌ █▌▐█▌  ████▌█▌▐█ ▐█▐▌ ▐▌  ███▐██  ▐█ ▐████▐███▐▌ ▐███▌▐█│
 8.2┤█████▌▐█▌▐█▌ █████▌██▐█ ██▐█ ▐▌▐████▐███▌▐█ █████▐███▐██▐████▐█│
    │████████▙██▌█████████▟█▖████▖▟██████▟██████▖████████████▟██████│
 5.8┤███████████▙███████████▙████▌██████████████▌███████████████████│
    │████████████████████████████▌██████████████████████████████████│
 3.3┤███████████████████████████████████████████████████████████████│
    └┬───────────────┬──────────────┬───────────────┬──────────────┬┘
     0.00          0.25           0.50            0.75          1.00
                               [x] xaxis
If you're on macOS and using iTerm2, click here:

You can get an iterm plot, the required dependencies can be installed via:

python3 -m pip install uproot-browser[iterm]

Or can be run via pipx without installing:

pipx run uproot-browser[iterm]

Adding the argument --iterm gives us the plot:

uproot-browser plot --testdata uproot-Event.root:hstat --iterm
iterm example

tree command:

uproot-browser tree --testdata uproot-Event.root
📁 uproot-Event.root
┣━━  <unnamed> TProcessID
┣━━ 🌴 T (1000)   ┗━━ 🌿 event Event
┃       ┣━━ 🌿 TObject (group of fUniqueID:uint32_t, fBits:uint32_t)          ┣━━ 🍁 fBits uint32_t
┃          ┗━━ 🍁 fUniqueID uint32_t
┃       ┣━━ 🍁 fClosestDistance unknown[]       ┣━━ 🍁 fEventName char*
┃       ┣━━ 🌿 fEvtHdr EventHeader
┃          ┣━━ 🍁 fEvtHdr.fDate int32_t
┃          ┣━━ 🍁 fEvtHdr.fEvtNum int32_t
┃          ┗━━ 🍁 fEvtHdr.fRun int32_t
┃       ┣━━ 🍁 fFlag uint32_t
┃       ┣━━ 🍁 fH TH1F
┃       ┣━━ 🍁 fHighPt TRefArray*
┃       ┣━━ 🍁 fIsValid bool
┃       ┣━━ 🍁 fLastTrack TRef
┃       ┣━━ 🍁 fMatrix[4][4] float[4][4]       ┣━━ 🍁 fMeasures[10] int32_t[10]       ┣━━ 🍁 fMuons TRefArray*
┃       ┣━━ 🍁 fNseg int32_t
┃       ┣━━ 🍁 fNtrack int32_t
┃       ┣━━ 🍁 fNvertex uint32_t
┃       ┣━━ 🍁 fTemperature float
┃       ┣━━ 🌿 fTracks TClonesArray*
┃          ┣━━ 🍃 fTracks.fBits uint32_t[]          ┣━━ 🍃 fTracks.fBx Float16_t[]          ┣━━ 🍃 fTracks.fBy Float16_t[]          ┣━━ 🍃 fTracks.fCharge Double32_t[]          ┣━━ 🍃 fTracks.fMass2 Float16_t[]          ┣━━ 🍃 fTracks.fMeanCharge float[]          ┣━━ 🍃 fTracks.fNpoint int32_t[]          ┣━━ 🍃 fTracks.fNsp uint32_t[]          ┣━━ 🍁 fTracks.fPointValue unknown[][]          ┣━━ 🍃 fTracks.fPx float[]          ┣━━ 🍃 fTracks.fPy float[]          ┣━━ 🍃 fTracks.fPz float[]          ┣━━ 🍃 fTracks.fRandom float[]          ┣━━ 🍃 fTracks.fTArray[3] float[][3]          ┣━━ 🍁 fTracks.fTriggerBits.fAllBits uint8_t[][]          ┣━━ 🍃 fTracks.fTriggerBits.fBits uint32_t[]          ┣━━ 🍃 fTracks.fTriggerBits.fNbits uint32_t[]          ┣━━ 🍃 fTracks.fTriggerBits.fNbytes uint32_t[]          ┣━━ 🍃 fTracks.fTriggerBits.fUniqueID uint32_t[]          ┣━━ 🍃 fTracks.fUniqueID uint32_t[]          ┣━━ 🍃 fTracks.fValid int16_t[]          ┣━━ 🍃 fTracks.fVertex[3] Double32_t[][3]          ┣━━ 🍃 fTracks.fXfirst Float16_t[]          ┣━━ 🍃 fTracks.fXlast Float16_t[]          ┣━━ 🍃 fTracks.fYfirst Float16_t[]          ┣━━ 🍃 fTracks.fYlast Float16_t[]          ┣━━ 🍃 fTracks.fZfirst Float16_t[]          ┗━━ 🍃 fTracks.fZlast Float16_t[]       ┣━━ 🌿 fTriggerBits TBits
┃          ┣━━ 🌿 fTriggerBits.TObject (group of fTriggerBits.fUniqueID:uint32_t, fTriggerBits.fBits:uint32_t)             ┣━━ 🍁 fTriggerBits.fBits uint32_t
┃             ┗━━ 🍁 fTriggerBits.fUniqueID uint32_t
┃          ┣━━ 🍃 fTriggerBits.fAllBits uint8_t[]          ┣━━ 🍁 fTriggerBits.fNbits uint32_t
┃          ┗━━ 🍁 fTriggerBits.fNbytes uint32_t
┃       ┣━━ 🍁 fType[20] int8_t[20]       ┗━━ 🍁 fWebHistogram TRef
┣━━ 📊 hstat TH1F (100)
┗━━ 📊 htime TH1F (10)

Development

pre-commit.ci status

See CONTRIBUTING.md for details on how to set up a development environment.

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

uproot_browser-0.8.4.tar.gz (84.7 kB view details)

Uploaded Source

Built Distribution

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

uproot_browser-0.8.4-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file uproot_browser-0.8.4.tar.gz.

File metadata

  • Download URL: uproot_browser-0.8.4.tar.gz
  • Upload date:
  • Size: 84.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for uproot_browser-0.8.4.tar.gz
Algorithm Hash digest
SHA256 34ce1ec813fbf1fb3c9c32711b329447ce5479ccab664fe10aae44f0d8ded602
MD5 af996ca6efa00dbe7c98b87a7adee7f8
BLAKE2b-256 e163268dbe040692488efaa71eba5063f43e97f3743cf47f9e0d832b76d9ee08

See more details on using hashes here.

Provenance

The following attestation bundles were made for uproot_browser-0.8.4.tar.gz:

Publisher: cd.yml on scikit-hep/uproot-browser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file uproot_browser-0.8.4-py3-none-any.whl.

File metadata

  • Download URL: uproot_browser-0.8.4-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for uproot_browser-0.8.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e02adbe1e06aad88b41f8fd5320698c332dfc7c064a4209c08b51e24856f0446
MD5 e6ced547c9509cc2ec4635a740cff180
BLAKE2b-256 1f8f71609a28eef9b0fa23dfc6fffbe71fa62d53513d484447c6333460b941b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for uproot_browser-0.8.4-py3-none-any.whl:

Publisher: cd.yml on scikit-hep/uproot-browser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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