Skip to main content

Adds a Ctrl+C handler to matplotlib figures for copying the figure to the clipboard

Project description

addcopyfighandler: Add a Ctrl+C handler to matplotlib figures for copying the figure to the clipboard

Importing this module (after importing matplotlib or pyplot) will add a handler to all subsequently-created matplotlib figures so that pressing Ctrl+C with a matplotlib figure window selected will copy the figure to the clipboard as an image. The copied image is generated through matplotlib.pyplot.savefig(), and thus is affected by the relevant rcParams settings (savefig.dpi, savefig.format, etc.).

Windows and Linux are currently supported. Pull requests implementing macOS support are welcome.

Uses code & concepts from:

Windows-specific behavior:

  • addcopyfighandler should work regardless of which graphical backend is being used by matplotlib (tkagg, gtk3agg, qtagg, etc.).
  • If matplotlib.rcParams['savefig.format'] is 'svg', the figure will be copied to the clipboard as an SVG.
  • If Pillow is installed, all non-SVG format specifiers will be overridden, and the figure will be copied to the clipboard as a Device-Independant Bitmap.
  • If Pillow is not installed, the supported format specifiers are 'png', 'jpg', 'jpeg', and 'svg'. All other format specifiers will be overridden, and the figure will be copied to the clipboard as PNG data.

Linux-specific behavior:

  • Requires either Qt or GTK libraries for clipboard interaction. Automatically detects which is being used from matplotlib.get_backend().
    • Qt support requires PyQt5, PyQt6, PySide2 or PySide6.
    • GTK support requires pycairo, PyGObject and PIL or pillow to be installed.
      • Only GTK 3 is supported, as GTK 4 has totally changed the way clipboard data is handled and I can't figure it out. I'm totally open to someone else solving this and submitting a PR if they want. I don't use GTK.
  • The figure will be copied to the clipboard as a PNG, regardless of matplotlib.rcParams['savefig.format']. Alas, SVG output is not currently supported. Pull requests that enable SVG support would be welcomed.

Releases

3.1.0: 2024-02-13

  • Add support for PyQt6 and PySide6 on Linux (already supported on Windows)

3.0.0: 2021-03-28

  • Add Linux support (tested on Ubuntu). Requires PyQt5, PySide2, or PyObject libraries; relevant library chosen based on matplotlib graphical backend in use. No SVG support.
  • On Windows, non SVG-formats will now use the Pillow library if installed, storing the figure to the clipboard as a device-indepenent bitmap (as previously handled in v2.0). This is compatible with a wider range of Windows applications.

2.1.0: 2020-08-27

  • Remove Pillow.
  • Add support for png & svg file formats.

2.0.0: 2019-06-07

  • Remove Qt requirement. Now use Pillow to grab the figure image, and win32clipboard to manage the Windows clipboard.

1.0.2: 2018-11-27

  • Force use of Qt4Agg or Qt5Agg. Some installs will default to TkAgg backend, which this module doesn't support. Forcing the backend to switch when loading this module saves the user from having to manually specify one of the Qt backends in every analysis.

1.0.1: 2018-11-27

  • Improve setup.py: remove need for importing module, add proper installation dependencies
  • Change readme from ReST to Markdown

1.0: 2017-08-09

  • Initial release

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

addcopyfighandler-3.1.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

addcopyfighandler-3.1.1-py2.py3-none-any.whl (6.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file addcopyfighandler-3.1.1.tar.gz.

File metadata

  • Download URL: addcopyfighandler-3.1.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.31.0

File hashes

Hashes for addcopyfighandler-3.1.1.tar.gz
Algorithm Hash digest
SHA256 6a8839d6235db8f9c25d96bf7c57d8e4b63b5942dc55c25b8d74b724dfb2bf92
MD5 a29ccb0be00b321b660a9f20dfab884f
BLAKE2b-256 7a34f2e5a9b1b076d1e8dada4b651911f25e48bb7c96c1e552d801c01daaa5be

See more details on using hashes here.

File details

Details for the file addcopyfighandler-3.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for addcopyfighandler-3.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a7869bfdb47f332552340be2203fe409c36080e153910a67ab5df8435826d113
MD5 ca49ccf594d5c09a8465fa46f4e75e74
BLAKE2b-256 2b2a942389b02f37cbca1a07825dab551ed016faf4a0d957a0d8da958b476102

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