pyqt 小工具-文件浏览器(1)

from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.Qt import *

import sys, os, time, types


class FileInfoTableWidget(QTableWidget):
    global_row_font = QFont('微软雅黑', 8)

    def __init__(self, parent=None, rootdir=None):
        super(FileInfoTableWidget, self).__init__(parent=parent)
        self.parent = parent
        self.rootDir = rootdir
        self._initUI()

    def _initUI(self):
        self.setGeometry(2, 32, 394, 364)
        self.verticalHeader().setVisible(False)
        self.setSelectionBehavior(QAbstractItemView.SelectRows)
        self.setEditTriggers(QAbstractItemView.NoEditTriggers)
        self.setColumnCount(4)
        headerLabels = ['文件名', '大小', '类型', '修改时间']
        for index, h in enumerate(headerLabels):
            item = QTableWidgetItem()
            item.setFont(self.global_row_font)
            item.setText(h)
            self.setHorizontalHeaderItem(index, item)

    def mouseDoubleClickEvent(self, evt:QMouseEvent):
        if evt.button() == Qt.LeftButton:
            dir = self.item(self.currentRow(), 0).text()
            type = self.item(self.currentRow(), 2).text()
            tmp = os.path.join(self.rootDir, dir)
            if type == 'File Folder':
                self.rootDir = tmp
                UpdateRowsThread(self, self.parent.update_callback, [self.rootDir, ]).start()
            else:
                print(tmp)
                os.system(tmp)

class UpdateRowsThread(QThread):
    _rowSignal = pyqtSignal(str, list)

    def __init__(self, parent=None, callback=None, args=[]):
        super(UpdateRowsThread, self).__init__(parent=parent)
        if type(callback) is not types.MethodType:
            raise Exception('callback is`t function')
        self._rowSignal.connect(callback)
        self.args = args

    def run(self):
        dir = self.args[0]
        if os.path.isdir(dir):
            files = os.listdir(dir)
            print(files)
            if files: self._rowSignal.emit(os.path.abspath(dir), files)

class Example(QWidget):

    def __init__(self):
        super(Example, self).__init__()
        self._initUI()

    def _initUI(self):
        self.setFixedSize(QSize(400, 400))
        self.combox = QComboBox(self)
        self.combox.setGeometry(0, 2, 200, 22)
        self.combox.setStyleSheet('border: 2px solid white;'
                                  'border-radius: 3px;'
                                  'padding: 1px 2px 1px 2px;'  # 针对于组合框中的文本内容
                                  'min-width: 9em;'
                                  )  # 组合框的最小宽度')
        self.combox.setEditable(True)
        dirs = QDir.drives()
        for fi in dirs:
            self.combox.addItem(fi.filePath())
        # ================浏览按钮
        self.btn_browser = QPushButton(self)
        self.btn_browser.setGeometry(210, 2, 60, 22)
        self.btn_browser.setText('浏览')
        self.btn_browser.setIcon(QIcon('./imgs/browser.png'))
        self.btn_browser.clicked.connect(self._btn_browser_clicked)
        # =================列表框
        self.currentPath = self.combox.currentText()
        self.fileInfoWidget = FileInfoTableWidget(self, self.currentPath)
        # ====更新线程
        UpdateRowsThread(self, self.update_callback, [self.currentPath]).start()
        self.show()

    def update_callback(self, absPath, rows):

        if self.fileInfoWidget.rowCount() > 0:
            for row in range(self.fileInfoWidget.rowCount()):
                self.fileInfoWidget.removeRow(0)
        for index, file in enumerate(rows):
            absFilePath = os.path.join(absPath, file)
            self.fileInfoWidget.insertRow(index)
            item0 = QTableWidgetItem()
            item0.setFont(self.fileInfoWidget.global_row_font)
            item0.setText(file)
            provider = QFileIconProvider()
            item0.setIcon(provider.icon(QFileInfo(absFilePath)))
            mtime = os.path.getmtime(absPath)
            self.fileInfoWidget.setRowHeight(index, 20)
            self.fileInfoWidget.setItem(index, 0, item0)
            # ============最后修改时间
            item1 = QTableWidgetItem()
            item1.setFont(self.fileInfoWidget.global_row_font)
            item1.setText(time.strftime('%Y-%m-%d %H-%M-%S', time.localtime(int(mtime))))
            self.fileInfoWidget.setItem(index, 3, item1)
            # =============文件类型
            item2 = QTableWidgetItem()
            item2.setFont(self.fileInfoWidget.global_row_font)
            fileType = provider.type(QFileInfo(absFilePath))
            item2.setText(fileType)
            self.fileInfoWidget.setItem(index, 2, item2)
            # =============文件大小
            item3 = QTableWidgetItem()
            item3.setFont(self.fileInfoWidget.global_row_font)
            item3.setText(str(os.path.getsize(absPath)) + 'KB')
            self.fileInfoWidget.setItem(index, 1, item3)
        self.combox.setCurrentText(absPath)
    def _btn_browser_clicked(self):
        fileDialog = QFileDialog()
        fileDialog.setViewMode(QFileDialog.Detail)
        fileDir = QFileDialog.getExistingDirectory(self, '浏览文件', os.environ['USERPROFILE'] + '\\desktop')


    # signal


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

 

转载于:https://www.cnblogs.com/alplf123/p/8465780.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python-pyqt5-hexview是一种基于Python和PyQt5这两个开发工具创建的十六进制数据查看器,是一个实用的工具,可以方便地查看二进制、十六进制数据。它提供了一种方便的方法来查看和编辑二进制文件,可以快速鉴定和分析数据,是开发人员、安全研究人员和网络管理员的理想选择。 Python-pyqt5-hexview可以明显提高开发人员的编程效率,节省时间和精力。它提供了一个友好的图形用户界面,用户可以在这个界面中选择要查看的数据文件,并自动将其转换成十六进制格式。具体而言,用户可以通过界面的文件浏览器来选择所需文件并打开文件。接下来,Python-pyqt5-hexview将自动将其读入并将数据转换成十六进制形式,并将其呈现在界面上。 Python-pyqt5-hexview支持多种常见的数据格式,以便用户可以轻松地查看和编辑复杂的数据文件。此外,它还具有许多其他功能,包括选择数据的起始和结束位置、搜索特定的十六进制模式、支持编辑和自动保存等。总之,Python-pyqt5-hexview是一个极为实用的数据查看器,为用户提供了一种方便、快速和高效的方式来查看和分析二进制和十六进制数据。 ### 回答2: Python-pyqt5-hexview是一种Python的库,是一个用于视觉化hex编辑器的插件。它使用PyQt5创建了一个用户界面,使用户能够以字节的形式查看和编辑二进制文件。此外,它还提供了搜索和替换功能,使用户能够快速准确地定位到需要编辑的信息。Python-pyqt5-hexview易于使用,具有良好的用户界面,是一款非常实用的工具。它可以被应用于各种领域,如数据恢复和修复、漏洞分析和漏洞利用。通过Python-pyqt5-hexview,用户可以查看和编辑数据,发现和利用漏洞,更好地理解和分析二进制文件。此外,它还可以被用于创建自定义hex编辑器,满足特定需求的个性化开发。总之,Python-pyqt5-hexview是一个功能强大的工具,为大量二进制文件的处理提供了方便、快捷的途径。 ### 回答3: Python-PyQt5-Hexview是一个Python和PyQt5编写的十六进制查看器,可以用于查看和编辑二进制文件。它具有用户友好的界面和丰富的操作功能,可以以字节为单位显示文件内容,并支持多种数据视图,方便用户查看和编辑不同格式的数据。此外,Python-PyQt5-Hexview还支持从文件和剪贴板中导入和导出数据,用户可以轻松地将文件内容复制到剪贴板并粘贴到其他应用程序中。除此之外,用户还可以将文件保存为常见的二进制文件格式,如.HEX或.BIN,方便用户进行后续的处理和分析。Python-PyQt5-Hexview还可以进行搜索和替换操作,用户可以快速定位和修改文件中的关键信息。Python-PyQt5-Hexview支持Windows、Linux和MacOS等多个操作系统,用户可以在不同平台上轻松使用它。总之,Python-PyQt5-Hexview是一个功能强大且易于使用的十六进制查看器,可以帮助用户快速查看和编辑二进制文件,是程序员和安全专家必备的工具之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值