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

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

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

相关推荐
ytttr8731 天前
隐马尔可夫模型(HMM)MATLAB实现范例
开发语言·算法·matlab
天远Date Lab1 天前
Python实战:对接天远数据手机号码归属地API,实现精准用户分群与本地化运营
大数据·开发语言·python
listhi5201 天前
基于Gabor纹理特征与K-means聚类的图像分割(Matlab实现)
开发语言·matlab
qq_433776421 天前
【无标题】
开发语言·php
Davina_yu1 天前
Windows 下升级 R 语言至最新版
开发语言·windows·r语言
阿珊和她的猫1 天前
IIFE:JavaScript 中的立即调用函数表达式
开发语言·javascript·状态模式
listhi5201 天前
卷积码编码和维特比译码的MATLAB仿真程序
开发语言·matlab
yuan199971 天前
基于主成分分析(PCA)的故障诊断MATLAB仿真
开发语言·matlab
J_liaty1 天前
Java版本演进:从JDK 8到JDK 21的特性革命与对比分析
java·开发语言·jdk
翔云 OCR API1 天前
发票查验接口详细接收参数说明-C#语言集成完整示例-API高效财税管理方案
开发语言·c#