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. 返回完整路径

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

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

相关推荐
oioihoii17 小时前
当无符号与有符号整数相遇:C++中的隐式类型转换陷阱
java·开发语言·c++
猪哥-嵌入式17 小时前
Go语言实战教学:从一个混合定时任务调度器(Crontab)深入理解Go的并发、接口与工程哲学
开发语言·后端·golang
互联网中的一颗神经元18 小时前
小白python入门 - 6. Python 分支结构——逻辑决策的核心机制
开发语言·数据库·python
妄小闲18 小时前
企业网站模版 免费PHP企业网站源码模板
开发语言
AhriProGramming18 小时前
Python学习快速上手文章推荐(持续更新)
开发语言·python·学习·1024程序员节
IDOlaoluo18 小时前
nginx-1.9.1.tar.gz 安装教程(详细步骤,从解压到启动)
开发语言·python
油炸自行车19 小时前
【Qt】VS Code配置Qt UI插件,vscode打开Qt Designer ,vscode打开Qt*.ui文件
qt·ui·cursor·qt designer·vscode插件·trae·qt ui
赵杰伦cpp19 小时前
C++的继承机制精讲
java·开发语言·c++·后端
百花~19 小时前
JVM(Java虚拟机)~
java·开发语言·jvm
沐苏瑶20 小时前
PHP反序列化漏洞
java·开发语言