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

pyqt6_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.

pyqt6_qhexedit-0.9.0-cp312-cp312-manylinux_2_28_x86_64.whl (61.4 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.28+ x86-64

pyqt6_qhexedit-0.9.0-cp311-none-win_amd64.whl (53.8 kB view details)

Uploaded CPython 3.11Windows x86-64

File details

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

File metadata

  • Download URL: pyqt6_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 pyqt6_qhexedit-0.9.0.tar.gz
Algorithm Hash digest
SHA256 ff7122336c4b2d5f4e540ef5104d93ccdc0096c7d826f3a62a0d178ff0ac746d
MD5 97861c77d74e1ca47a26b83f003c428f
BLAKE2b-256 9ba898e127a2b7e211f129df349b1407953411fbab60de179d10061b87cee51c

See more details on using hashes here.

File details

Details for the file pyqt6_qhexedit-0.9.0-cp312-cp312-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for pyqt6_qhexedit-0.9.0-cp312-cp312-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 cccc29bd5071542eda152d8933d0dc7c860f109320d7979f57a6b50f78c0675e
MD5 97dacc20407c99f202d14af89ca52cc0
BLAKE2b-256 5ec9685d8f70dc2279038095151828577549f9c1f3ee0dd7cce882b42a41cb59

See more details on using hashes here.

File details

Details for the file pyqt6_qhexedit-0.9.0-cp311-none-win_amd64.whl.

File metadata

File hashes

Hashes for pyqt6_qhexedit-0.9.0-cp311-none-win_amd64.whl
Algorithm Hash digest
SHA256 0f328a094555a1f20c055f36c0b6266b32bf8e0d3e99b696e34f65b6110a4db0
MD5 ca03129ff3bebbf585109495d84b18f7
BLAKE2b-256 f3b5fc5ceccf586cb928a387baccdfc0efbe62501d0dc8eba9e86fe2ec5918e9

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