PyQt学习之单个和多个文件选择并显示文件名

1. 采用Qt_Designer画出页面 ,保存名为test.ui,并生成test.py

流程可参考:PyQT学习之Stacked Widget控件

生成的test.py代码:

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

# Form implementation generated from reading ui file 'test.ui'
#
# Created by: PyQt5 UI code generator 5.15.4
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.


from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(679, 446)
        self.pushButton_1 = QtWidgets.QPushButton(Form)
        self.pushButton_1.setGeometry(QtCore.QRect(50, 30, 201, 28))
        self.pushButton_1.setObjectName("pushButton_1")
        self.pushButton_2 = QtWidgets.QPushButton(Form)
        self.pushButton_2.setGeometry(QtCore.QRect(420, 30, 201, 28))
        self.pushButton_2.setObjectName("pushButton_2")
        self.textBrowser = QtWidgets.QTextBrowser(Form)
        self.textBrowser.setGeometry(QtCore.QRect(50, 70, 571, 351))
        self.textBrowser.setObjectName("textBrowser")

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

    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))
        self.pushButton_1.setText(_translate("Form", "打开单个文件"))
        self.pushButton_2.setText(_translate("Form", "打开多个文件"))

2. 编写main.py

# encoding=utf-8
import sys
from PyQt5.QtWidgets import *

import test


class fileSelect(QWidget, test.Ui_Form):
    def __init__(self):
        super().__init__()
        self.setupUi(self)

        self.pushButton_1.clicked.connect(self.btn_single)
        self.pushButton_2.clicked.connect(self.btn_multi)

    def btn_single(self):
        # 选择单个文件
        filename, _ = QFileDialog.getOpenFileName(self,
                                                  "选取文件",
                                                  r"D:\Project",
                                                  "All Files (*);;Text Files (*.csv)")
        self.textBrowser.setText(filename)
    def btn_multi(self):
        # 选择多个文件
        files, filetype = QFileDialog.getOpenFileNames(self,
                                                       "多文件选择",
                                                       r"D:\Project",  # 起始路径
                                                       "All Files (*);;Text Files (*.csv)")
        # 清屏
        self.textBrowser.clear()
        # 将选择的文件名都打印到textBrowser控件中
        for file in files:
            self.textBrowser.append(file)


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

3. 单个文件测试:


4. 多个文件测试:

 

 

  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,可以使用PyQt5中的QTreeView和QStandardItemModel来实现。以下是一个简单的例子: ```python import sys from PyQt5.QtWidgets import QApplication, QTreeView, QFileSystemModel, QVBoxLayout, QWidget, QStandardItemModel, QStandardItem import json class JsonTreeView(QWidget): def __init__(self, json_file): super().__init__() self.json_file = json_file self.initUI() def initUI(self): # 创建布局 layout = QVBoxLayout(self) # 创建QStandardItemModel model = QStandardItemModel(self) model.setHorizontalHeaderLabels(['Name', 'Content']) # 读取json文件 with open(self.json_file, 'r') as f: data = json.load(f) # 遍历json文件并添加到model中 for name, content in data.items(): item_name = QStandardItem(name) item_content = QStandardItem(content) model.appendRow([item_name, item_content]) # 创建QTreeView并设置model tree = QTreeView(self) tree.setModel(model) # 将QTreeView添加到布局中 layout.addWidget(tree) # 设置窗口大小 self.setGeometry(300, 300, 800, 600) self.setWindowTitle('JSON Tree View') self.show() if __name__ == '__main__': app = QApplication(sys.argv) json_file = 'example.json' ex = JsonTreeView(json_file) sys.exit(app.exec_()) ``` 在这个例子中,我们创建了一个JsonTreeView类,它继承自QWidget,并在initUI()方法中创建了一个QStandardItemModel并读取了json文件。然后,我们遍历json文件并将其添加到模型中。最后,我们创建了一个QTreeView并将模型设置为其数据源,最终将QTreeView添加到布局中。 你只需要将json_file变量设置为你想要读取的json文件的路径即可。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值