QT生成保存 Excel 文件的默认路径,导出的文件后缀自动加(1)(2)等等

//生成保存 Excel 文件的默认路径 QString MainWidget::getDefaultFilePath() const { QString basePath = pathEdit->text(); if (basePath.isEmpty() || !QDir(basePath).exists()) { basePath = QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation); } return QDir(basePath).filePath(QString("Data_%1.xlsx").arg(QDateTime::currentDateTime().toString("yyyyMMdd_HHmmss"))); }导出的文件后缀自动加(1)(2)等等

复制代码
QString MainWidget::getDefaultFilePath() const {
    QString basePath = pathEdit->text();
    if (basePath.isEmpty() || !QDir(basePath).exists()) {
        basePath = QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation);
    }

    QDateTime currentDateTime = QDateTime::currentDateTime();
    QString baseFileName = QString("Data_%1").arg(currentDateTime.toString("yyyyMMdd_HHmmss"));
    QString fileName = baseFileName;
    int count = 1;

    // 检查文件是否存在,如果存在则添加序号
    while (QFile::exists(QDir(basePath).filePath(fileName + ".xlsx"))) {
        fileName = QString("%1(%2)").arg(baseFileName).arg(count++);
    }

    return QDir(basePath).filePath(fileName + ".xlsx");
}

修改说明:

  1. 生成基础文件名

    • 使用当前日期时间生成基础文件名,格式为 Data_YYYYMMDD_HHMMSS
  2. 检查文件是否存在

    • 如果文件已存在,则在基础文件名后添加序号 (1), (2) 等,直到找到一个未被使用的文件名。
  3. 返回完整路径

    • 返回带有唯一文件名的完整路径。

通过这种修改,每次导出文件时,系统会自动检查目标路径下是否已有同名文件。如果有,则在文件名后添加序号,确保文件名唯一,避免覆盖已有文件。

相关推荐
怀旧,17 分钟前
【C语言】C语言经典小游戏:贪吃蛇(下)
c语言·开发语言·数据结构
余厌厌厌1 小时前
Golang学习之旅
开发语言·学习·golang
Code_流苏1 小时前
Python趣学篇:用Pygame打造绚烂流星雨动画
开发语言·python·pygame·图形编程·粒子系统·流星雨特效
clock的时钟1 小时前
c++面向对象第4天---拷贝构造函数与深复制
开发语言·c++
t198751281 小时前
Java连接Redis和基础操作命令
java·开发语言·redis
秋名RG1 小时前
深入理解享元模式:用Java实现高效对象共享
java·开发语言·享元模式
蜗牛的旷野1 小时前
华为OD机试_2025 B卷_小华地图寻宝(Python,100分)(附详细解题思路)
开发语言·python·华为od
勤奋的小王同学~2 小时前
(javaSE)Java数组进阶:数组初始化 数组访问 数组中的jvm 空指针异常
开发语言·python
一刀到底2112 小时前
java 微服务中,微服务相互调用 feign 和flux 如何选择
java·开发语言·微服务
秋风&萧瑟2 小时前
【C++】类的构造函数
开发语言·c++