2013-09-12 14:01:52 +08:00
PyQtGraph
=========
2020-12-22 21:29:39 -08:00
[![PyPi ](https://img.shields.io/pypi/v/pyqtgraph.svg )](https://pypi.org/project/pyqtgraph/)
[![conda-forge ](https://img.shields.io/conda/vn/conda-forge/pyqtgraph.svg )](https://anaconda.org/conda-forge/pyqtgraph)
2020-12-23 23:04:30 -08:00
[![Build Status ](https://github.com/pyqtgraph/pyqtgraph/workflows/main/badge.svg )](https://github.com/pyqtgraph/pyqtgraph/actions/?query=workflow%3Amain)
[![CodeQL Status ](https://github.com/pyqtgraph/pyqtgraph/workflows/codeql/badge.svg )](https://github.com/pyqtgraph/pyqtgraph/actions/?query=workflow%3Acodeql)
2020-12-22 21:29:39 -08:00
[![Documentation Status ](https://readthedocs.org/projects/pyqtgraph/badge/?version=latest )](https://pyqtgraph.readthedocs.io/en/latest/?badge=latest)
[![Total alerts ](https://img.shields.io/lgtm/alerts/g/pyqtgraph/pyqtgraph.svg?logo=lgtm&logoWidth=18 )](https://lgtm.com/projects/g/pyqtgraph/pyqtgraph/alerts/)
[![Language grade: Python ](https://img.shields.io/lgtm/grade/python/g/pyqtgraph/pyqtgraph.svg?logo=lgtm&logoWidth=18 )](https://lgtm.com/projects/g/pyqtgraph/pyqtgraph/context:python)
2021-01-18 12:38:28 +08:00
A pure-Python graphics library for PyQt5/PyQt6/PySide2/PySide6
2013-09-12 14:22:26 +08:00
2020-06-06 20:34:21 -07:00
Copyright 2020 Luke Campagnola, University of North Carolina at Chapel Hill
2013-09-12 14:22:26 +08:00
< http: / / www . pyqtgraph . org >
2013-09-12 14:01:52 +08:00
2018-04-25 16:55:10 -07:00
PyQtGraph is intended for use in mathematics / scientific / engineering applications.
Despite being written entirely in python, the library is fast due to its
heavy leverage of numpy for number crunching, Qt's GraphicsView framework for
2D display, and OpenGL for 3D display.
2013-09-12 14:22:26 +08:00
2013-09-12 14:01:52 +08:00
Requirements
------------
2013-09-12 14:22:26 +08:00
2020-12-22 12:25:06 -06:00
pyqtgraph has adopted [NEP 29 ](https://numpy.org/neps/nep-0029-deprecation_policy.html ).
This project supports:
* All minor versions of Python released 42 months prior to the project, and at minimum the two latest minor versions.
* All minor versions of numpy released in the 24 months prior to the project, and at minimum the last three minor versions.
2021-01-20 12:41:29 +08:00
* All minor versions of Qt 5 and Qt 6 currently supported by upstream Qt
2020-12-22 12:25:06 -06:00
Currently this means:
* Python 3.7+
2021-01-20 12:41:29 +08:00
* Qt 5.12-6.0
2019-06-10 22:24:53 -07:00
* Required
2021-01-18 12:38:28 +08:00
* PyQt5, PyQt6, PySide2 or PySide6
2020-12-22 12:25:06 -06:00
* `numpy` 1.17+
2019-06-10 22:24:53 -07:00
* Optional
2019-11-12 09:02:08 -08:00
* `scipy` for image processing
2019-06-10 22:24:53 -07:00
* `pyopengl` for 3D graphics
2020-12-22 12:16:05 -08:00
* `pyopengl` on macOS Big Sur only works with python 3.9.1+
2019-06-10 22:24:53 -07:00
* `hdf5` for large hdf5 binary format support
2021-01-20 12:41:29 +08:00
* `colorcet` for supplemental colormaps
2021-01-19 21:26:24 -08:00
* [`cupy` ](https://docs.cupy.dev/en/stable/install.html ) for CUDA-enhanced image processing
* On Windows, CUDA toolkit must be >= 11.1
2019-06-10 22:24:53 -07:00
Qt Bindings Test Matrix
-----------------------
2021-01-20 12:41:29 +08:00
The following table represents the python environments we test in our CI system. Our CI system uses Ubuntu 20.04, Windows Server 2019, and macOS 10.15 base images.
2019-06-10 22:24:53 -07:00
2020-12-22 12:16:05 -08:00
| Qt-Bindings | Python 3.7 | Python 3.8 | Python 3.9 |
2020-12-22 12:25:06 -06:00
| :------------- | :----------------: | :----------------: | :----------------: |
2020-12-22 12:16:05 -08:00
| PySide2-5.12 | :white_check_mark: | :x: | :x: |
| PyQt5-5.12 | :white_check_mark: | :x: | :x: |
2021-01-20 12:41:29 +08:00
| PySide2-5.15 | :x: | :white_check_mark: | :x: |
2021-01-18 12:38:28 +08:00
| PyQt5-5.15 | :x: | :white_check_mark: | :x: |
2021-01-20 12:41:29 +08:00
| PySide6-6.0 | :x: | :x: | :white_check_mark: |
2021-01-18 12:38:28 +08:00
| PyQt6-6.0 | :x: | :x: | :white_check_mark: |
2013-09-12 14:01:52 +08:00
Support
-------
2018-04-25 16:55:10 -07:00
2019-05-22 22:07:30 -07:00
* Report issues on the [GitHub issue tracker ](https://github.com/pyqtgraph/pyqtgraph/issues )
* Post questions to the [mailing list / forum ](https://groups.google.com/forum/?fromgroups#!forum/pyqtgraph ) or [StackOverflow ](https://stackoverflow.com/questions/tagged/pyqtgraph )
2013-09-12 14:01:52 +08:00
Installation Methods
--------------------
2013-09-12 14:22:26 +08:00
2019-05-22 22:07:30 -07:00
* From PyPI:
* Last released version: `pip install pyqtgraph`
2020-06-06 20:34:21 -07:00
* Latest development version: `pip install git+https://github.com/pyqtgraph/pyqtgraph@master`
2019-06-10 22:24:53 -07:00
* From conda
2020-06-06 20:34:21 -07:00
* Last released version: `conda install -c conda-forge pyqtgraph`
2018-07-10 16:14:59 -07:00
* To install system-wide from source distribution: `python setup.py install`
* Many linux package repositories have release versions.
* To use with a specific project, simply copy the pyqtgraph subdirectory
2019-05-22 22:07:30 -07:00
anywhere that is importable from your project.
2013-09-12 14:01:52 +08:00
Documentation
-------------
2013-09-12 14:22:26 +08:00
2020-12-23 23:04:30 -08:00
The official documentation lives at [pyqtgraph.readthedocs.io ](https://pyqtgraph.readthedocs.io )
2020-06-06 20:34:21 -07:00
The easiest way to learn pyqtgraph is to browse through the examples; run `python -m pyqtgraph.examples` to launch the examples application.
2021-03-08 09:22:13 -08:00
Used By
-------
Here is a partial listing of some of the applications that make use of PyQtGraph!
* [ACQ4 ](https://github.com/acq4/acq4 )
* [Orange3 ](https://orangedatamining.com/ )
* [neurotic ](neurotic )
* [Joulescope ](https://www.joulescope.com/ )
* [rapidtide ](https://rapidtide.readthedocs.io/en/latest/ )
* [argos ](https://github.com/titusjan/argos )
* [PySpectra ](http://hasyweb.desy.de/services/computing/Spock/node138.html )
* [Semi-Supervised Semantic Annotator ](https://gitlab.com/ficsresearch/s3ah )
Do you use PyQtGraph in your own project, and want to add it to the list? Submit a pull request to update this listing!