No project description provided
Project description
CERN CMS Run Registry client
A Python client for the new RunRegistry. A Python client for the old RunRegistry can be found here.
Installation
pip install runregistryclient
Prerequisites
Since mai 2019 the run registry requires authenticaion with a CERN user account. Therefore you need to setup your CERN Grid User Certificate as instructed in the cernrequests package:
See: https://github.com/ptrstn/cernrequests#prerequisites
Usage
Example
If you want a single run, do this:
import runreg
runreg.get(run_number=327600)
If you prefer a non-nested JSON output, use the flat=True parameter.
import runreg
runreg.get(run_number=327600, flat=True)
runreg assumes the tracker workspace by default.
If you want to change it, you can do so by specifying the workspace attribute:
import runreg
runreg.get(run_number=327600, workspace="global")
Multiple filters at once
If you want to use several filters at once, for example, to filter according to a sequence number range with certain criteria, you can do it this way:
import runreg
runreg.get(run_number=[(327596, ">="), (327744, "lte")], name=("%Cosmics%", "like"))
Or if you prefer Django like lookup fields:
import runreg
runreg.get(run_number__gte=327596, run_number__lte=327744, name__like="%Cosmics%")
Operators
Following operators are supported:
=oreq(assumed per default)>=orgte>orgt<=orlte<orltlike
The operators should be specified as the second element of a (value, operator) tuple such as (321123, "<=").
Attributes
All available attributes can be found in the docs folder under attributes.md.
Development
Python version 3.5 or higher is required.
If you want to improve this software, you should follow these steps:
git clone https://github.com/ptrstn/runregistryclient
cd runregistryclient
python -m venv venv
. venv/bin/activate
pip install -e .
pip install -r testing-requirements.txt
Running Tests
pytest --cov .
FAQ
How do you filter by subcomponent status?
If you want to filter for subcomponent states such as Pixel or SiStrip, you must use the attribute names specified in the RunRegistry API. Unfortunately, they contain "-" and "." characters, so you need to use a little trick.
For example, to filter for the Track Status in the workspace Tracker then you need to do:
import runreg
runreg.get(**{"tracker-track.status": "GOOD"})
You can still combine this with other attributes and options:
import runreg
runreg.get(flat=True, run_number=[(327596, ">="), (327744, "lte")], **{"pix.status": "EXCLUDED", "strip.status":"GOOD"})
Whats the difference between tracker-track and track?
track is used for the global workspace, while tracker-track uses the tracker workspace.
The same is true for tracker-pix / pix and tracker-strip / strip.
Does this work with Python 2.7?
No.
References
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file runregistryclient-0.3.0.tar.gz.
File metadata
- Download URL: runregistryclient-0.3.0.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.1.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c70cfc0835e18fca5e218402847d3609774c7c0cd6369ce0ac2e7081f168962e
|
|
| MD5 |
396a99a4fb4da60ec6fb7294a78319bc
|
|
| BLAKE2b-256 |
54bbb5e8096c2893b126d292df343a7d849310226b628eed3b44e24a1bc776b4
|
File details
Details for the file runregistryclient-0.3.0-py3-none-any.whl.
File metadata
- Download URL: runregistryclient-0.3.0-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.1.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
346a950a11b7dcbeb7acec0f0e58b768333afe73b80621d61a68bb2262a59d56
|
|
| MD5 |
fce756acc8a00fe09834e19cf29d3785
|
|
| BLAKE2b-256 |
d5bcf8b0da78cf14ab81218ddb2e693ab3216c4c517e38446e350bf17134c714
|