PyQt5 制作帮助文档查看器

帮助文档查看器是很多程序中必备要素,而利用Qt中的QTreeView组件可以很方便的查看文件,而QTextBrowser可以直接显示格式化的MarkDown文本。因此可以利用这两个组件制作一个帮助文件查看器。
本程序的文件结构如下:

.
├── main.py
└── ui
    └── docViewer.ui
└── docs --这里放帮助文档
    ├── a.md
    ├── b.md
    └── c.md 

如果使用命令

conda install matplotlib 

会自动一起安装上pyqt 5.12 和 pyqtchart 5.12
但是qt 5.12 的文字查看器并没有显示Markdown或Html的功能。
需要用命令升级一下

pip install --upgrade pyqt5

运行界面

在这里插入图片描述

Python代码

from PyQt5.QtWidgets import QApplication,QWidget,QFileSystemModel
from PyQt5.uic import loadUi
from PyQt5.QtGui import QFont


import sys
import os


class Doc_Viewer(QWidget):

    def __init__(self,parent=None) -> None:
        super().__init__(parent)
        #加载UI文件
        loadUi('./ui/docViewer.ui',self)

        self.__initUi()
        

    def __initUi(self):
        '''
        初始化运行逻辑
        '''

         #建立文件模型
        self.fileModel = QFileSystemModel()

        #设置模型根目录
        pathIndex=self.fileModel.setRootPath(os.path.abspath("./docs/"))
        print(self.fileModel.rootPath())

        #绑定视图与模型
        self.treeView.setModel(self.fileModel)
        #视图根目录文件模型根目录要一致
        self.treeView.setRootIndex(pathIndex)

        #这里隐藏了文件的信息展示
        for i in [1,2,3]:
            self.treeView.setColumnHidden(i, True)


        #建立左侧树视图与右侧文本查看器的连接
        self.treeView.clicked.connect(self.loadDoc)

        
        
    def loadDoc(self,QpathIndex):
        '''
        加载文件
        '''

        filepath=  self.fileModel.filePath(QpathIndex)
        print(f"选择了文件【{filepath}】" )

        if os.path.isfile(filepath):
            # 读取文件内容
            markdown=open(filepath,mode="r",encoding="utf-8").read()
            # 加入到浏览框
            self.textBrowser.setMarkdown(markdown)
        



if __name__=="__main__":
    app = QApplication(sys.argv)
    app.setFont(QFont("黑体",12))

    w = Doc_Viewer()
    w.show()
    sys.exit(app.exec())

UI文件

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>Form</class>
 <widget class="QWidget" name="Form">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>857</width>
    <height>920</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Form</string>
  </property>
  <layout class="QHBoxLayout" name="horizontalLayout">
   <item>
    <widget class="QTreeView" name="treeView">
     <property name="sizePolicy">
      <sizepolicy hsizetype="Fixed" vsizetype="Expanding">
       <horstretch>100</horstretch>
       <verstretch>0</verstretch>
      </sizepolicy>
     </property>
    </widget>
   </item>
   <item>
    <widget class="QTextBrowser" name="textBrowser">
     <property name="documentTitle">
      <string/>
     </property>
     <property name="readOnly">
      <bool>true</bool>
     </property>

    </widget>
   </item>
  </layout>
 </widget>
 <resources/>
 <connections/>
</ui>


  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高堂明镜悲白发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值