Skip to main content

Python bindings for the QHexEdit Widget

Project description

QHexEdit2

.github/workflows/badge-library.yml .github/workflows/badge-binary.yml .github/workflows/badge-designer-plugin.yml

Application QHexEdit2 in Action

QHexEdit is a hex editor widget written in C++ for the Qt (Qt5, Qt6) framework. It is a simple editor for binary data, just like QPlainTextEdit is for text data. There are sip configuration files included, so it is easy to create bindings for PyQt and you can use this widget also in python.

QHexEdit takes the data of a QByteArray (setData()) and shows it. You can use the mouse or the keyboard to navigate inside the widget. If you hit the keys (0..9, a..f) you will change the data. Changed data is highlighted and can be accessed via data().

Normally QHexEdit works in the overwrite mode. You can set overwrite mode(false) and insert data. In this case the size of data() increases. It is also possible to delete bytes (del or backspace), here the size of data decreases.

You can select data with keyboard hits or mouse movements. The copy-key will copy the selected data into the clipboard. The cut-key copies also but deletes it afterwards. In overwrite mode, the paste function overwrites the content of the (does not change the length) data. In insert mode, clipboard data will be inserted. The clipboard content is expected in ASCII Hex notation. Unknown characters will be ignored.

QHexEdit comes with undo/redo functionality. All changes can be undone, by pressing the undo-key (usually ctr-z). They can also be redone afterwards. The undo/redo framework is cleared, when setData() sets up a new content for the editor. You can search data inside the content with indexOf() and lastIndexOf(). The replace() function is to change located subdata. This 'replaced' data can also be undone by the undo/redo framework.

QHexEdit is based on QIODevice, that's why QHexEdit can handle big amounts of data. The size of edited data can be more then two gigabytes without any restrictions.

Using QHexEdit (C++)

You can read the documentation of the project here. You find in the sources a C++ example, that shows how to use the QHexedit widget. The binaries for the example for the Windows platform are stored with the respective release.

Using QHexEdit (Python)

To use QHexEdit with Python install it from PyPi:

$ # for PyQt5
$ pip install PyQt5 PyQt5-QHexEdit
$
$ # for PyQt6
$ pip install PyQt6 PyQt6-QHexEdit

The sources and binaries for Windows 64 bit and Linux 64 bit are stored on PyPi. For all other targets, the widget must be compiled locally. For this, the corresponding Qt version including the developer packages must be installed. It makes sense to compile the C++ project first. If this is possible with qmake, it is also possible to compile the PyQt bindings. This requires python build.

There is also a python example available.

Contributing to QHexEdit

We love to receive contributions. You can submit bug reports here. If you are a developer, you can pick up a work item and start to realize super exciting features or fix bugs. We also like to receive enhancement proposals or translation support.

License

Copyright (C) 2015-2016 Winfried Simon

This software may be used under the terms of the GNU Lesser General
Public License version 2.1 as published by the Free Software Foundation
and appearing in the file license.txt included in the packaging of this file.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

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

pyqt5_qhexedit-0.9.0.tar.gz (31.3 kB view details)

Uploaded Source

Built Distributions

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

pyqt5_qhexedit-0.9.0-cp312-cp312-manylinux_2_17_x86_64.whl (56.9 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.17+ x86-64

pyqt5_qhexedit-0.9.0-cp39-none-win_amd64.whl (48.8 kB view details)

Uploaded CPython 3.9Windows x86-64

File details

Details for the file pyqt5_qhexedit-0.9.0.tar.gz.

File metadata

  • Download URL: pyqt5_qhexedit-0.9.0.tar.gz
  • Upload date:
  • Size: 31.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for pyqt5_qhexedit-0.9.0.tar.gz
Algorithm Hash digest
SHA256 a98dbb2843867aba58aca84299a5aa9a3af70ae27d782f0f3585cb6d9cd7a774
MD5 5150cc7d57a40d6f00b2655ad36fdc44
BLAKE2b-256 068ca18762c64aa32e907821cedbf00d00ebe7e3752cffad15caffa59166855c

See more details on using hashes here.

File details

Details for the file pyqt5_qhexedit-0.9.0-cp312-cp312-manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for pyqt5_qhexedit-0.9.0-cp312-cp312-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 2bc47748ac545d94ae4635ae87486b902e676c05f101036b51325ceaa7d4823e
MD5 52872532580c4a5f8ae18f842b8888b6
BLAKE2b-256 579078e5e772921f88495a0c4c99dda71045fe7567102c0f5a40f34af559fbf8

See more details on using hashes here.

File details

Details for the file pyqt5_qhexedit-0.9.0-cp39-none-win_amd64.whl.

File metadata

File hashes

Hashes for pyqt5_qhexedit-0.9.0-cp39-none-win_amd64.whl
Algorithm Hash digest
SHA256 9f362e49d4f86c8158575ff6a06ef74afbd0db214d141d247d6e18c4bce5bc3c
MD5 65dac93734ec63bd426a6c29f54dd247
BLAKE2b-256 08115dcde125f8cdb62f6bcfc18fd6bf7e58cae808d05e52c290b1399876ecfc

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