news 2026/3/3 15:58:13

C++、Qt中打开文件夹获取文件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++、Qt中打开文件夹获取文件
void Qt_operateping::onOpenFileClicked() { // 打开文件对话框,供用户选择图片文件 // getOpenFileName() 函数的四个参数依次是: // 1. 父组件,通常传递当前对象 this // 2. 对话框标题 // 3. 初始打开的文件路径(此处是 D 盘根目录) // 4. 过滤器,限制显示的文件类型(这里是 PNG 和 JPG 格式的图片) QString filename = QFileDialog::getOpenFileName(this, "请选择图片", "D:/", "图片(*.png *.jpg)"); // 如果用户没有选择任何文件,直接返回 if (filename.isEmpty()) { return; } // 将选择的文件路径显示在界面上的 QLineEdit 中 //lineEdit_path->setText(filename); ui.lineEdit->setText(filename); // 将选择的图片加载成 QPixmap 对象,并显示在 QLabel 中 //label_image->setPixmap(QPixmap(filename)); ui.label_2->setPixmap(QPixmap(filename)); } void Qt_operateping::onOpenFileClicked1() { // 获取应用程序的配置文件路径,存放在当前应用的目录下 QString config_path = qApp->applicationDirPath() + "/config/Setting.ini"; qDebug() << config_path; // 输出配置文件路径,便于调试查看 // 使用 QSettings 读取 ini 文件中的配置信息,文件不存在时会自动创建 QSettings* pIniSet = new QSettings(config_path, QSettings::IniFormat); // 从配置文件中读取上次使用的路径,如果没有记录则返回空字符串 QString lastPath = pIniSet->value("/LastPath/path").toString(); // 如果没有上次记录的路径,使用系统默认的图片目录 if (lastPath.isEmpty()) { // QStandardPaths::writableLocation 获取系统中常用路径 lastPath = QStandardPaths::writableLocation(QStandardPaths::PicturesLocation); } // 打开文件选择对话框,初始路径设置为 lastPath QString filename = QFileDialog::getOpenFileName(this, "请选择图片", lastPath, "图片(*.png *.jpg)"); // 如果用户没有选择文件,直接返回 if (filename.isEmpty()) { return; } // 将选择的文件路径显示在界面上的文本框中 ui.lineEdit->setText(filename); QPixmap* pix = new QPixmap(filename); pix->scaled(ui.label_2->size(), Qt::KeepAspectRatioByExpanding); ui.label_2->setScaledContents(true); // 显示选择的图片 //ui.label_2->setPixmap(QPixmap(filename)); ui.label_2->setPixmap(*pix); // 获取文件路径的目录部分,更新配置文件中的路径 int end = filename.lastIndexOf("/"); QString _path = filename.left(end); pIniSet->setValue("/LastPath/path", _path); // 删除 QSettings 对象,释放内存 delete pIniSet; pIniSet = nullptr; qDebug() << _path; // 输出更新后的路径,便于调试查看 } void Qt_operateping::onOpenFileClicked2() { // 获取应用程序的配置文件路径,存放在当前应用的目录下 QString config_path = qApp->applicationDirPath() + "/config/Setting.ini"; qDebug() << config_path; // 输出配置文件路径,便于调试查看 // 使用 std::unique_ptr 管理 QSettings 对象,自动管理内存 std::unique_ptr<QSettings> pIniSet(new QSettings(config_path, QSettings::IniFormat)); // 从配置文件中读取上次使用的路径 QString lastPath = pIniSet->value("/LastPath/path").toString(); // 如果没有上次记录的路径,使用系统默认的图片目录 if (lastPath.isEmpty()) { lastPath = QStandardPaths::writableLocation(QStandardPaths::PicturesLocation); } // 打开文件选择对话框,初始路径设置为 lastPath QString filename = QFileDialog::getOpenFileName(this, "请选择图片", lastPath, "图片(*.png *.jpg)"); // 如果用户没有选择文件,直接返回 if (filename.isEmpty()) { return; } // 将选择的文件路径显示在界面上的文本框中 ui.lineEdit->setText(filename); // 显示选择的图片 ui.label_2->setPixmap(QPixmap(filename)); // 获取文件路径的目录部分,更新配置文件中的路径 int end = filename.lastIndexOf("/"); QString _path = filename.left(end); pIniSet->setValue("/LastPath/path", _path); qDebug() << _path; // 输出更新后的路径,便于调试查看 }
  • QSettings
    这是 Qt 提供的一个便捷的类,用于保存应用程序的配置信息,支持使用 ini 文件或者注册表。这里使用 ini 文件存储用户上次选择的路径。在这个例子中,配置文件是Setting.ini,其中存储了用户上次打开文件的路径。

    • pIniSet->value("/LastPath/path").toString():读取配置中的路径值。

    • pIniSet->setValue("/LastPath/path", _path):在用户选择完图片后,保存其路径。

  • QStandardPaths::writableLocation()
    用于获取操作系统中特定类型的文件夹,例如图片、文档等。在这里当用户第一次打开程序时,程序会自动使用系统的图片目录作为初始路径。

  • **QString::lastIndexOf()**** 和 ****QString::left()**
    用于字符串的操作,lastIndexOf()查找路径中的最后一个/left()截取文件路径的目录部分。

特点与改进:

在第一个的基础上添加了路径记忆功能,每次打开文件选择对话框时,都会显示上次用户选择的文件夹,大大提高了用户体验。同时,它将路径存储在 ini 文件中,确保下次程序启动时可以继续记住路径。

2、

使用智能指针优化内存管理:

2中,我们手动newdeleteQSettings对象,虽然这能正常工作,但容易导致内存泄漏问题。为了安全管理内存,2使用了 C++11 引入的智能指针std::unique_ptr,从而自动管理对象的生命周期。

  • std::unique_ptr
    智能指针是 C++11 引入的内存管理工具,能够在对象不再需要时自动释放内存,从而避免内存泄漏。在这里使用std::unique_ptr来管理QSettings对象的生命周期,无需手动delete
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/25 11:15:47

工程化实践:AIGC创作者如何构建可扩展的创作工作流

引言随着AI生成内容技术的快速发展&#xff0c;越来越多的创作者开始探索将AIGC工具应用于商业化创作。然而&#xff0c;从个人实验到稳定输出&#xff0c;需要一套系统化、工程化的解决方案。本文将分享我在某AIGC创作平台上的实践经历&#xff0c;重点探讨如何构建可扩展的创…

作者头像 李华
网站建设 2026/2/16 0:25:56

Kalidokit与Three.js VRM渲染器:虚拟角色动作捕捉完整解决方案

Kalidokit与Three.js VRM渲染器&#xff1a;虚拟角色动作捕捉完整解决方案 【免费下载链接】harmonyos-tutorial HarmonyOS Tutorial. 《跟老卫学HarmonyOS开发》 项目地址: https://gitcode.com/GitHub_Trending/ha/harmonyos-tutorial 在虚拟角色应用快速发展的今天&a…

作者头像 李华
网站建设 2026/2/25 14:07:24

3倍效率提升:ThingsBoard批量管理终极指南

3倍效率提升&#xff1a;ThingsBoard批量管理终极指南 【免费下载链接】thingsboard Open-source IoT Platform - Device management, data collection, processing and visualization. 项目地址: https://gitcode.com/GitHub_Trending/th/thingsboard 你是否也曾面临这…

作者头像 李华
网站建设 2026/2/28 5:44:46

3大痛点解析:Flink监控体系为何总是失效?终极解决方案来了!

你是否经历过Flink作业突然卡死却找不到原因&#xff1f;背压监控数据一片空白&#xff1f;检查点频繁失败却无从下手&#xff1f;这些困扰开发者的监控难题&#xff0c;本文将为你一一解决&#xff01;&#x1f680; 【免费下载链接】flink 项目地址: https://gitcode.com/…

作者头像 李华
网站建设 2026/2/27 8:51:24

Latest:macOS应用更新的终极完整指南

Latest&#xff1a;macOS应用更新的终极完整指南 【免费下载链接】Latest A small utility app for macOS that makes sure you know about all the latest updates to the apps you use. 项目地址: https://gitcode.com/gh_mirrors/la/Latest Latest 是一款专为 macOS …

作者头像 李华