如何在pyqt5中添加日志?

问题描述 投票:-1回答:1

我是pyqt5的新手,我正在尝试使用日志创建一个程序,我遵循this

我使用QTDesigner为我的程序制作了一个GUI:

贵.朋友

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'GUI.ui'
#
# Created by: PyQt5 UI code generator 5.10.1
#
# WARNING! All changes made in this file will be lost!
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import Qt

from info import info_os, now, jam, wificonnectedto, ipaddress, mac,gatew,status
from Btn import Switch



class Ui_widps(object):
    def setupUi(self, widps):
        widps.setObjectName("widps")
        widps.resize(714, 548)
        widps.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
        widps.setAcceptDrops(False)
        widps.setDocumentMode(False)
        widps.setDockNestingEnabled(False)
        widps.setUnifiedTitleAndToolBarOnMac(False)
        self.centralwidget = QtWidgets.QWidget(widps)
        self.centralwidget.setObjectName("centralwidget")
        self.verticalLayoutWidget = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget.setGeometry(QtCore.QRect(10, 30, 101, 101))
        self.verticalLayoutWidget.setObjectName("verticalLayoutWidget")
        self.LayoutInformation = QtWidgets.QVBoxLayout(self.verticalLayoutWidget)
        self.LayoutInformation.setContentsMargins(0, 0, 0, 0)
        self.LayoutInformation.setObjectName("LayoutInformation")
        self.txOs = QtWidgets.QLabel(self.verticalLayoutWidget)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txOs.setFont(font)
        self.txOs.setObjectName("txOs")
        self.LayoutInformation.addWidget(self.txOs)
        self.txCdate = QtWidgets.QLabel(self.verticalLayoutWidget)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txCdate.setFont(font)
        self.txCdate.setObjectName("txCdate")
        self.LayoutInformation.addWidget(self.txCdate)
        self.txCtime = QtWidgets.QLabel(self.verticalLayoutWidget)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txCtime.setFont(font)
        self.txCtime.setObjectName("txCtime")
        self.LayoutInformation.addWidget(self.txCtime)
        self.verticalLayoutWidget_2 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_2.setGeometry(QtCore.QRect(10, 161, 81, 111))
        self.verticalLayoutWidget_2.setObjectName("verticalLayoutWidget_2")
        self.LayoutConnectionInfo = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_2)
        self.LayoutConnectionInfo.setContentsMargins(0, 0, 0, 0)
        self.LayoutConnectionInfo.setObjectName("LayoutConnectionInfo")
        self.txConnto = QtWidgets.QLabel(self.verticalLayoutWidget_2)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txConnto.setFont(font)
        self.txConnto.setObjectName("txConnto")
        self.LayoutConnectionInfo.addWidget(self.txConnto)
        self.txtIpad = QtWidgets.QLabel(self.verticalLayoutWidget_2)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txtIpad.setFont(font)
        self.txtIpad.setObjectName("txtIpad")
        self.LayoutConnectionInfo.addWidget(self.txtIpad)
        self.txMacAd = QtWidgets.QLabel(self.verticalLayoutWidget_2)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txMacAd.setFont(font)
        self.txMacAd.setObjectName("txMacAd")
        self.LayoutConnectionInfo.addWidget(self.txMacAd)
        self.txGateway = QtWidgets.QLabel(self.verticalLayoutWidget_2)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txGateway.setFont(font)
        self.txGateway.setObjectName("txGateway")
        self.LayoutConnectionInfo.addWidget(self.txGateway)
        self.verticalLayoutWidget_3 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_3.setGeometry(QtCore.QRect(80, 280, 119, 31))
        self.verticalLayoutWidget_3.setObjectName("verticalLayoutWidget_3")
        self.LayoutWirelessSec = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_3)
        self.LayoutWirelessSec.setContentsMargins(0, 0, 0, 0)
        self.LayoutWirelessSec.setObjectName("LayoutWirelessSec")
        self.txtWirelessSec = QtWidgets.QLabel(self.verticalLayoutWidget_3)
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.txtWirelessSec.setFont(font)
        self.txtWirelessSec.setObjectName("txtWirelessSec")
        self.LayoutWirelessSec.addWidget(self.txtWirelessSec)
        self.verticalLayoutWidget_4 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_4.setGeometry(QtCore.QRect(10, 320, 161, 161))
        self.verticalLayoutWidget_4.setObjectName("verticalLayoutWidget_4")
        self.verticalLayout_4 = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_4)
        self.verticalLayout_4.setContentsMargins(0, 0, 0, 0)
        self.verticalLayout_4.setObjectName("verticalLayout_4")
        self.txtArp = QtWidgets.QLabel(self.verticalLayoutWidget_4)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txtArp.setFont(font)
        self.txtArp.setObjectName("txtArp")
        self.verticalLayout_4.addWidget(self.txtArp)
        self.txtRapp = QtWidgets.QLabel(self.verticalLayoutWidget_4)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txtRapp.setFont(font)
        self.txtRapp.setObjectName("txtRapp")
        self.verticalLayout_4.addWidget(self.txtRapp)
        self.txtSniff = QtWidgets.QLabel(self.verticalLayoutWidget_4)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.txtSniff.setFont(font)
        self.txtSniff.setObjectName("txtSniff")
        self.verticalLayout_4.addWidget(self.txtSniff)
        self.verticalLayoutWidget_5 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_5.setGeometry(QtCore.QRect(340, 90, 371, 301))
        self.verticalLayoutWidget_5.setObjectName("verticalLayoutWidget_5")
        self.verticalLayout_5 = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_5)
        self.verticalLayout_5.setContentsMargins(0, 0, 0, 0)
        self.verticalLayout_5.setObjectName("verticalLayout_5")
        self.verticalLayoutWidget_6 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_6.setGeometry(QtCore.QRect(450, 10, 151, 71))
        self.verticalLayoutWidget_6.setObjectName("verticalLayoutWidget_6")
        self.verticalLayout_6 = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_6)
        self.verticalLayout_6.setContentsMargins(0, 0, 0, 0)
        self.verticalLayout_6.setObjectName("verticalLayout_6")
        self.txtGraph = QtWidgets.QLabel(self.verticalLayoutWidget_6)
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.txtGraph.setFont(font)
        self.txtGraph.setAlignment(QtCore.Qt.AlignCenter)
        self.txtGraph.setObjectName("txtGraph")
        self.verticalLayout_6.addWidget(self.txtGraph)
        self.verticalLayoutWidget_8 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_8.setGeometry(QtCore.QRect(170, 320, 161, 171))
        self.verticalLayoutWidget_8.setObjectName("verticalLayoutWidget_8")
        self.LayoutBtnWirelessSec = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_8)
        self.LayoutBtnWirelessSec.setContentsMargins(0, 0, 0, 0)
        self.LayoutBtnWirelessSec.setObjectName("LayoutBtnWirelessSec")
        self.Arppbtn = Switch()
        self.Arppbtn.setObjectName("Arppbtn")
        self.LayoutBtnWirelessSec.addWidget(self.Arppbtn)
        self.Rappbtn = Switch()
        self.Rappbtn.setObjectName("Rappbtn")
        self.LayoutBtnWirelessSec.addWidget(self.Rappbtn)
        self.Sniffpbtn = Switch()
        self.Sniffpbtn.setObjectName("Sniffpbtn")
        self.LayoutBtnWirelessSec.addWidget(self.Sniffpbtn)
        self.horizontalLayoutWidget = QtWidgets.QWidget(self.centralwidget)
        self.horizontalLayoutWidget.setGeometry(QtCore.QRect(410, 390, 247, 80))
        self.horizontalLayoutWidget.setObjectName("horizontalLayoutWidget")
        self.horizontalLayout = QtWidgets.QHBoxLayout(self.horizontalLayoutWidget)
        self.horizontalLayout.setContentsMargins(0, 0, 0, 0)
        self.horizontalLayout.setObjectName("horizontalLayout")
        self.txtthreat = QtWidgets.QLabel(self.horizontalLayoutWidget)
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.txtthreat.setFont(font)
        self.txtthreat.setObjectName("txtthreat")
        self.horizontalLayout.addWidget(self.txtthreat)
        self.txttotalthreat = QtWidgets.QLabel(self.horizontalLayoutWidget)
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.txttotalthreat.setFont(font)
        self.txttotalthreat.setObjectName("txttotalthreat")
        self.horizontalLayout.addWidget(self.txttotalthreat)
        self.verticalLayoutWidget_7 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_7.setGeometry(QtCore.QRect(109, 29, 141, 101))
        self.verticalLayoutWidget_7.setObjectName("verticalLayoutWidget_7")
        self.LayoutFungsiInfo = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_7)
        self.LayoutFungsiInfo.setContentsMargins(0, 0, 0, 0)
        self.LayoutFungsiInfo.setObjectName("LayoutFungsiInfo")
        self.osinfotxt = QtWidgets.QLabel(self.verticalLayoutWidget_7)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.osinfotxt.setFont(font)
        self.osinfotxt.setObjectName("osinfotxt")
        self.LayoutFungsiInfo.addWidget(self.osinfotxt)
        self.cdatetxt = QtWidgets.QLabel(self.verticalLayoutWidget_7)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.cdatetxt.setFont(font)
        self.cdatetxt.setObjectName("cdatetxt")
        self.LayoutFungsiInfo.addWidget(self.cdatetxt)
        self.ctimetxt = QtWidgets.QLabel(self.verticalLayoutWidget_7)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.ctimetxt.setFont(font)
        self.ctimetxt.setObjectName("ctimetxt")
        self.LayoutFungsiInfo.addWidget(self.ctimetxt)
        self.txtinfo = QtWidgets.QLabel(self.centralwidget)
        self.txtinfo.setGeometry(QtCore.QRect(90, 10, 91, 19))
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.txtinfo.setFont(font)
        self.txtinfo.setObjectName("txtinfo")
        self.verticalLayoutWidget_9 = QtWidgets.QWidget(self.centralwidget)
        self.verticalLayoutWidget_9.setGeometry(QtCore.QRect(90, 160, 181, 111))
        self.verticalLayoutWidget_9.setObjectName("verticalLayoutWidget_9")
        self.LayoutFungsiWCI = QtWidgets.QVBoxLayout(self.verticalLayoutWidget_9)
        self.LayoutFungsiWCI.setContentsMargins(0, 0, 0, 0)
        self.LayoutFungsiWCI.setObjectName("LayoutFungsiWCI")
        self.contotxt = QtWidgets.QLabel(self.verticalLayoutWidget_9)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.contotxt.setFont(font)
        self.contotxt.setObjectName("contotxt")
        self.LayoutFungsiWCI.addWidget(self.contotxt)
        self.ipaddtxt = QtWidgets.QLabel(self.verticalLayoutWidget_9)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.ipaddtxt.setFont(font)
        self.ipaddtxt.setObjectName("ipaddtxt")
        self.LayoutFungsiWCI.addWidget(self.ipaddtxt)
        self.mactxt = QtWidgets.QLabel(self.verticalLayoutWidget_9)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.mactxt.setFont(font)
        self.mactxt.setObjectName("mactxt")
        self.LayoutFungsiWCI.addWidget(self.mactxt)
        self.getwaytxt = QtWidgets.QLabel(self.verticalLayoutWidget_9)
        font = QtGui.QFont()
        font.setPointSize(8)
        self.getwaytxt.setFont(font)
        self.getwaytxt.setObjectName("getwaytxt")
        self.LayoutFungsiWCI.addWidget(self.getwaytxt)
        self.label_5 = QtWidgets.QLabel(self.centralwidget)
        self.label_5.setGeometry(QtCore.QRect(41, 140, 171, 20))
        font = QtGui.QFont()
        font.setPointSize(10)
        font.setBold(True)
        font.setWeight(75)
        self.label_5.setFont(font)
        self.label_5.setObjectName("label_5")
        widps.setCentralWidget(self.centralwidget)
        self.statusbar = QtWidgets.QStatusBar(widps)
        self.statusbar.setContextMenuPolicy(QtCore.Qt.DefaultContextMenu)
        self.statusbar.setSizeGripEnabled(True)
        self.statusbar.setObjectName("statusbar")
        widps.setStatusBar(self.statusbar)
        self.menubar = QtWidgets.QMenuBar(widps)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 714, 27))
        self.menubar.setObjectName("menubar")
        self.menuFile = QtWidgets.QMenu(self.menubar)
        self.menuFile.setObjectName("menuFile")
        self.menuAbout = QtWidgets.QMenu(self.menubar)
        self.menuAbout.setObjectName("menuAbout")
        widps.setMenuBar(self.menubar)
        self.actionSave_Logs = QtWidgets.QAction(widps)
        self.actionSave_Logs.setObjectName("actionSave_Logs")
        self.actionExit = QtWidgets.QAction(widps)
        self.actionExit.setObjectName("actionExit")
        self.actionInstruction = QtWidgets.QAction(widps)
        self.actionInstruction.setObjectName("actionInstruction")
        self.actionAbout = QtWidgets.QAction(widps)
        self.actionAbout.setObjectName("actionAbout")
        self.menuFile.addAction(self.actionSave_Logs)
        self.menuFile.addAction(self.actionExit)
        self.menuAbout.addAction(self.actionInstruction)
        self.menuAbout.addAction(self.actionAbout)
        self.menubar.addAction(self.menuFile.menuAction())
        self.menubar.addAction(self.menuAbout.menuAction())

        self.retranslateUi(widps)
        QtCore.QMetaObject.connectSlotsByName(widps)

    def retranslateUi(self, widps):
        _translate = QtCore.QCoreApplication.translate
        widps.setWindowTitle(_translate("widps", "Wireless Intrusion Prevention System"))
        self.txOs.setText(_translate("widps", "Operating System :"))
        self.txCdate.setText(_translate("widps", "Current Date :"))
        self.txCtime.setText(_translate("widps", "Current Time :"))
        self.txConnto.setText(_translate("widps", "Connected To : "))
        self.txtIpad.setText(_translate("widps", "IP Address :"))
        self.txMacAd.setText(_translate("widps", "Mac Address :"))
        self.txGateway.setText(_translate("widps", "Gateway :"))
        self.txtWirelessSec.setText(_translate("widps", "Wireless Security"))
        self.txtArp.setText(_translate("widps", "ARP Protection"))
        self.txtRapp.setText(_translate("widps", "Rogue Access Point Protection"))
        self.txtSniff.setText(_translate("widps", "Sniffing Protection"))
        self.txtGraph.setText(_translate("widps", "Logs"))
        self.Arppbtn.setText(_translate("widps", "On"))
        self.Rappbtn.setText(_translate("widps", "On"))
        self.Sniffpbtn.setText(_translate("widps", "On"))
        self.txtthreat.setText(_translate("widps", "Total Threats Detection :"))
        self.txttotalthreat.setText(_translate("widps", "0"))
        self.osinfotxt.setText(_translate("widps",info_os))
        self.cdatetxt.setText(_translate("widps",now.toString(Qt.DefaultLocaleLongDate)))
        self.ctimetxt.setText(_translate("widps", jam.toString(Qt.DefaultLocaleLongDate)))
        self.txtinfo.setText(_translate("widps", "Information"))
        self.contotxt.setText(_translate("widps",wificonnectedto))
        self.ipaddtxt.setText(_translate("widps", ipaddress))
        self.mactxt.setText(_translate("widps", mac))
        self.getwaytxt.setText(_translate("widps", gatew))
        self.statusbar.showMessage("Status: "+status)
        self.label_5.setText(_translate("widps", "Wireless Connection Info"))
        self.menuFile.setTitle(_translate("widps", "File"))
        self.menuAbout.setTitle(_translate("widps", "Help"))
        self.actionSave_Logs.setText(_translate("widps", "Save Logs"))
        self.actionExit.setText(_translate("widps", "Exit"))
        self.actionInstruction.setText(_translate("widps", "Instruction"))
        self.actionAbout.setText(_translate("widps", "About"))


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    widps = QtWidgets.QMainWindow()
    ui = Ui_widps()
    ui.setupUi(widps)
    widps.show()
    sys.exit(app.exec_())

我添加日志的程序逻辑:

我ID PS.朋友

import sys
from PyQt5 import QtWidgets
import logging
from gui import Ui_widps

class QTextEditLogger(logging.Handler):
    def __init__(self, parent):
        super().__init__()
        self.widget = QtWidgets.QPlainTextEdit(parent)
        self.widget.setReadOnly(True)

    def emit(self, record):
        msg = self.format(record)
        self.widget.appendPlainText(msg)


class DialogLog(QtWidgets.QDialog, QtWidgets.QPlainTextEdit,Ui_widps):
    def __init__(self, parent=None):
        super().__init__(parent)
        self.setupUi(self)
        logTextBox = QTextEditLogger(self)
        logTextBox.setFormatter(logging.Formatter('%(asctime)s - %(levelname)s - %(message)s'))
        logging.getLogger().addHandler(logTextBox)
        logging.getLogger().setLevel(logging.DEBUG)
        self.verticalLayout_5.addWidget(logTextBox.widget)

app = QtWidgets.QApplication(sys.argv)
dlglog = DialogLog()
dlglog.show()
dlglog.raise_()
sys.exit(app.exec_())

info.py =无线收集信息的功能

import platform
from PyQt5.QtCore import QDate, Qt, QTime
import subprocess
import uuid
import socket
import netifaces
import urllib.request
import sys
info_os = platform.system() + platform.release()
now = QDate.currentDate()
jam = QTime.currentTime()

try:
    url = "https://www.google.com"
    urllib.request.urlopen(url)
    status = "Wifi Terkoneksi"
except ConnectionError:
    status = "Wifi tidak terkoneksi silahkan koneksikan dahulu"
    sys.exit(0)

if platform.system() == "Linux":
    var = subprocess.check_output(["iwgetid","-r"])
elif platform.system() == "Windows":
    cmd = "netsh wlan show interface=Wi-Fi mode=ssid | findstr SSID"
    procs = subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,stderr=subprocess.STDOUT)
    var = procs.communicate()[0]
wificonnectedto = var

s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
s.connect(("8.8.8.8", 80))
ipaddress = s.getsockname()[0]
s.close()

gw = netifaces.gateways()
gatew = gw['default'][netifaces.AF_INET][0]

mac1 = str(hex(uuid.getnode()))
mac = mac1[2:4]+ ':' +mac1[4:6]+ ':' +mac1[6:8]+ ':' +mac1[8:10]+ ':' +mac1[10:12]+ ':' +mac1[12:14]

Btn.py =按钮功能

    from PyQt5.QtCore import QPropertyAnimation, QRectF, QSize, Qt, pyqtProperty
from PyQt5.QtGui import QPainter
from PyQt5.QtWidgets import (
    QAbstractButton,
    QApplication,
    QSizePolicy,
    QWidget,
)


class Switch(QAbstractButton):
    def __init__(self, parent=None, track_radius=10, thumb_radius=8):
        super().__init__(parent=parent)
        self.setCheckable(True)
        self.setSizePolicy(QSizePolicy.Fixed, QSizePolicy.Fixed)

        self._track_radius = track_radius
        self._thumb_radius = thumb_radius

        self._margin = max(0, self._thumb_radius - self._track_radius)
        self._base_offset = max(self._thumb_radius, self._track_radius)
        self._end_offset = {
            True: lambda: self.width() - self._base_offset,
            False: lambda: self._base_offset,
        }
        self._offset = self._base_offset

        palette = self.palette()
        if self._thumb_radius > self._track_radius:
            self._track_color = {
                True: palette.highlight(),
                False: palette.dark(),
            }
            self._thumb_color = {
                True: palette.highlight(),
                False: palette.light(),
            }
            self._text_color = {
                True: palette.highlightedText().color(),
                False: palette.dark().color(),
            }
            self._thumb_text = {
                True: '',
                False: '',
            }
            self._track_opacity = 0.5
        else:
            self._thumb_color = {
                True: palette.highlightedText(),
                False: palette.light(),
            }
            self._track_color = {
                True: palette.highlight(),
                False: palette.dark(),
            }
            self._text_color = {
                True: palette.highlight().color(),
                False: palette.dark().color(),
            }
            self._thumb_text = {
                True: '✔',
                False: '✕',
            }
            self._track_opacity = 1

    @pyqtProperty(int)
    def offset(self):
        return self._offset

    @offset.setter
    def offset(self, value):
        self._offset = value
        self.update()

    def sizeHint(self):  # pylint: disable=invalid-name
        return QSize(
            4 * self._track_radius + 2 * self._margin,
            2 * self._track_radius + 2 * self._margin,
        )

    def setChecked(self, checked):
        super().setChecked(checked)
        self.offset = self._end_offset[checked]()

    def resizeEvent(self, event):
        super().resizeEvent(event)
        self.offset = self._end_offset[self.isChecked()]()

    def paintEvent(self, event):  # pylint: disable=invalid-name, unused-argument
        p = QPainter(self)
        p.setRenderHint(QPainter.Antialiasing, True)
        p.setPen(Qt.NoPen)
        track_opacity = self._track_opacity
        thumb_opacity = 1.0
        text_opacity = 1.0
        if self.isEnabled():
            track_brush = self._track_color[self.isChecked()]
            thumb_brush = self._thumb_color[self.isChecked()]
            text_color = self._text_color[self.isChecked()]
        else:
            track_opacity *= 0.8
            track_brush = self.palette().shadow()
            thumb_brush = self.palette().mid()
            text_color = self.palette().shadow().color()

        p.setBrush(track_brush)
        p.setOpacity(track_opacity)
        p.drawRoundedRect(
            self._margin,
            self._margin,
            self.width() - 2 * self._margin,
            self.height() - 2 * self._margin,
            self._track_radius,
            self._track_radius,
        )
        p.setBrush(thumb_brush)
        p.setOpacity(thumb_opacity)
        p.drawEllipse(
            self.offset - self._thumb_radius,
            self._base_offset - self._thumb_radius,
            2 * self._thumb_radius,
            2 * self._thumb_radius,
        )
        p.setPen(text_color)
        p.setOpacity(text_opacity)
        font = p.font()
        font.setPixelSize(1.5 * self._thumb_radius)
        p.setFont(font)
        p.drawText(
            QRectF(
                self.offset - self._thumb_radius,
                self._base_offset - self._thumb_radius,
                2 * self._thumb_radius,
                2 * self._thumb_radius,
            ),
            Qt.AlignCenter,
            self._thumb_text[self.isChecked()],
        )

    def mouseReleaseEvent(self, event):  # pylint: disable=invalid-name
        super().mouseReleaseEvent(event)
        if event.button() == Qt.LeftButton:
            anim = QPropertyAnimation(self, b'offset', self)
            anim.setDuration(120)
            anim.setStartValue(self.offset)
            anim.setEndValue(self._end_offset[self.isChecked()]())
            anim.start()

    def enterEvent(self, event):  # pylint: disable=invalid-name
        self.setCursor(Qt.PointingHandCursor)
        super().enterEvent(event)


def main():
    app = QApplication([])

    # Thumb size < track size (Gitlab style)
    w = QWidget()
    w.setLayout(l)
    w.show()

    app.exec()


if __name__ == '__main__':
    main()

我尝试运行该程序,但我收到这样的错误:

File "/home/s1gnific4nt/IDSIPS/widps.py", line 36, in <module>
    dlglog = DialogLog()
  File "/home/s1gnific4nt/IDSIPS/widps.py", line 23, in __init__
    self.setupUi(self)
  File "/home/s1gnific4nt/IDSIPS/gui.py", line 22, in setupUi
    widps.setDocumentMode(False)
AttributeError: 'DialogLog' object has no attribute 'setDocumentMode'

为什么会发生这种情况,我该如何解决这个问题?

python python-3.x pyqt pyqt5 qt-designer
1个回答
0
投票

您的错误很简单,与日志无关,但是当您使用Qt Designer时,您选择了主窗口模板,当您使用该模板时,您必须使用QMainWindow,因为当您将其转换为.py并使用该类的方法时例如,setDocumentMode()方法是QMainWindow的一部分,而不是QDialog,因此它会抛出错误,因此解决方案是更改继承。另一方面,没有必要继承QTextEditLogger所以删除它,我不明白为什么你指出的问题的答案使用它。

import sys
import logging
from PyQt5 import QtCore, QtWidgets

from gui import Ui_widps


class QTextEditLogger(logging.Handler):
    def __init__(self, parent):
        super().__init__()
        self.widget = QtWidgets.QPlainTextEdit(parent)
        self.widget.setReadOnly(True)

    def emit(self, record):
        msg = self.format(record)
        self.widget.appendPlainText(msg)


class MainWindow(QtWidgets.QMainWindow, Ui_widps):
    def __init__(self, parent=None):
        super().__init__(parent)
        self.setupUi(self)
        logTextBox = QTextEditLogger(self)
        logTextBox.setFormatter(logging.Formatter('%(asctime)s - %(levelname)s - %(message)s'))
        logging.getLogger().addHandler(logTextBox)
        logging.getLogger().setLevel(logging.DEBUG)
        self.verticalLayout_5.addWidget(logTextBox.widget)

        # test: add log after 1 second
        QtCore.QTimer.singleShot(1000, self.test)

    def test(self):
        logging.debug('damn, a bug')
        logging.info('something to remember')
        logging.warning('that\'s not right')
        logging.error('foobar')

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.