qt 使用CRUD方式操作excel

//注意点,列名不能使用单独使用time,不能有-,最好不要有冒号和空格,这些容易出错,导致无法插入

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
    //#include <QFileDialog>
    //#include <QSqlError>
    //#include <QSqlDatabase>
    //#include <QSqlQuery>
    //#include <QDateTime>
    //QT       += sql
 
    //myDebug;
 
    ui->data_fileinfo->setText(QStringLiteral("写入excel中..."));
    QString qStringExcelName = fileName+".xls";
    QString sheetName = "";
 
 
    //=================================================
    QString qstringSql = "";
    //if(qStringExcelSheetName.length()<=0) qStringExcelSheetName = QDateTime::currentDateTime().toString("yyyy_MM_dd___hh_mm_ss");//Excel内sheet页的名字//
    //if(qStringExcelSheetName.length()<=0) qStringExcelSheetName = qStringExcelName+"_"+QString::number(languageflag);//Excel内sheet页的名字//
    QSqlDatabase qsqldatabaseDB = QSqlDatabase::addDatabase("QODBC","excelexport");//连接到excel。使用QODBC的方式操作Excel,该方式同样可操作数据库
    if( !qsqldatabaseDB.isValid()){
        return;//type error
    }
 
    QString qstringDsn =  "DRIVER={Microsoft Excel Driver (*.xls)};"
                  "DSN='';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=";
    qstringDsn += ("\"" + qStringExcelName + "\"" + ";DBQ=" + qStringExcelName);//确定要操作的excel信息,可直接百度,有源码教程。
    qsqldatabaseDB.setDatabaseName(qstringDsn);
 
    if( !qsqldatabaseDB.open()){// open connection
        return//! db error
    }
    QSqlQuery qsqlqueryDB(qsqldatabaseDB);//查询命令
 
    sheetName="688";
    qstringSql = QString("CREATE TABLE [%1] (").arg(sheetName);
    qstringSql += "["+sheetName+"byte0_1] varchar(200),["+sheetName+"byte2_3] varchar(200),["+sheetName+"byte4_5] varchar(200),["+sheetName+"byte6_7] varchar(200),["+sheetName+"_time] varchar(200))";
    qsqlqueryDB.prepare( qstringSql); if( !qsqlqueryDB.exec()) {  }
 
    //myDebugMsg(qstringSql);
 
 
    QString qstringSql688 = QString("INSERT INTO [%1] (").arg( sheetName);//insert a record
    qstringSql688 += sheetName+"byte0_1,"+sheetName+"byte2_3,"+sheetName+"byte4_5,"+sheetName+"byte6_7,"+sheetName+"_time)VALUES(:p0,:p1,:p2,:p3,:p4)";
 
    //myDebugMsg(qstringSql688);
 
    sheetName="788";
    qstringSql = QString("CREATE TABLE [%1] (").arg(sheetName);
    qstringSql += "["+sheetName+"byte0_1] varchar(200),["+sheetName+"byte2_3] varchar(200),["+sheetName+"byte4_5] varchar(200),["+sheetName+"byte6_7] varchar(200),["+sheetName+"_time] varchar(200))";
    qsqlqueryDB.prepare( qstringSql); if( !qsqlqueryDB.exec()) {  }
 
    QString qstringSql788 = QString("INSERT INTO [%1] (").arg( sheetName);//insert a record
    qstringSql788 += sheetName+"byte0_1,"+sheetName+"byte2_3,"+sheetName+"byte4_5,"+sheetName+"byte6_7,"+sheetName+"_time)VALUES(:p0,:p1,:p2,:p3,:p4)";
 
 
    sheetName="794";
    qstringSql = QString("CREATE TABLE [%1] (").arg(sheetName);
    qstringSql += "["+sheetName+"byte0_1] varchar(200),["+sheetName+"byte2_3] varchar(200),["+sheetName+"byte4_5] varchar(200),["+sheetName+"byte6_7] varchar(200),["+sheetName+"_time] varchar(200))";
    qsqlqueryDB.prepare( qstringSql); if( !qsqlqueryDB.exec()) {  }
 
    QString qstringSql794 = QString("INSERT INTO [%1] (").arg( sheetName);//insert a record
    qstringSql794 += sheetName+"byte0_1,"+sheetName+"byte2_3,"+sheetName+"byte4_5,"+sheetName+"byte6_7,"+sheetName+"_time)VALUES(:p0,:p1,:p2,:p3,:p4)";
 
 
    sheetName="894";
    qstringSql = QString("CREATE TABLE [%1] (").arg(sheetName);
    qstringSql += "["+sheetName+"byte0_1] varchar(200),["+sheetName+"byte2_3] varchar(200),["+sheetName+"byte4_5] varchar(200),["+sheetName+"byte6_7] varchar(200),["+sheetName+"_time] varchar(200))";
    qsqlqueryDB.prepare( qstringSql); if( !qsqlqueryDB.exec()) { myDebug;  }
 
    //myDebugMsg(qstringSql);
 
    QString qstringSql894 = QString("INSERT INTO [%1] (").arg(sheetName);//insert a record
    qstringSql894 += sheetName+"byte0_1,"+sheetName+"byte2_3,"+sheetName+"byte4_5,"+sheetName+"byte6_7,"+sheetName+"_time)VALUES(:p0,:p1,:p2,:p3,:p4)";
 
    //myDebugMsg(qstringSql894);
 
 
    //从log中读取文件,然后分别写入对应的位置
    QFile file(fileName+".log");
    if(!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
        myDebug;return;
    }
    while(!file.atEnd()) {
        QByteArray line = file.readLine();
        QString info(line);
 
        info = info.trimmed();
        if(info.length()==0 || info.contains(":")==false || info.split(":").at(1).length()<16)continue;
        QStringList li = info.split(";"); //688:0102030405060708,2021_11_19__14_00_30__333,space //688:0102030405060708,space,space //688:0102030405060708,space
        li.append(" ");
        QString t = li.at(1);
        QString data = li.at(0).split(":").at(1);
 
        // 小端格式     高字节在后,低字节在前
        short tem = 0; unsigned char _tem[10];memset(_tem,0,10);
        for(int i=0;i<8;i++){ _tem[i]=data.mid(i*2,2).toInt(nullptr,16); }
        memcpy(&tem,_tem+0,2); QString byte0 = QString::number(tem);
        memcpy(&tem,_tem+2,2); QString byte2 = QString::number(tem);
        memcpy(&tem,_tem+4,2); QString byte4 = QString::number(tem);
        memcpy(&tem,_tem+6,2); QString byte6 = QString::number(tem);
 
//        QString tem;
//        tem = data.mid(2,2)+data.mid(0,2);   QString byte0 = QString::number(tem.toShort(nullptr,16));
//        tem = data.mid(6,2)+data.mid(4,2);   QString byte2 = QString::number(tem.toShort(nullptr,16));
//        tem = data.mid(10,2)+data.mid(8,2);  QString byte4 = QString::number(tem.toShort(nullptr,16));
//        tem = data.mid(14,2)+data.mid(12,2); QString byte6 = QString::number(tem.toShort(nullptr,16));
 
 
        if(false){myDebug;}
        else if(info.startsWith("688")){ qsqlqueryDB.prepare( qstringSql688); }
        else if(info.startsWith("788")){ qsqlqueryDB.prepare( qstringSql788); }
        else if(info.startsWith("794")){ qsqlqueryDB.prepare( qstringSql794); }
        else if(info.startsWith("894")){ qsqlqueryDB.prepare( qstringSql894); }
        else { continue; }
 
        qsqlqueryDB.bindValue(":p0",byte0);
        qsqlqueryDB.bindValue(":p1",byte2);
        qsqlqueryDB.bindValue(":p2",byte4);
        qsqlqueryDB.bindValue(":p3",byte6);
        qsqlqueryDB.bindValue(":p4",t);
        if( !qsqlqueryDB.exec()) {
            //myDebug;
        }
 
    }
    ui->data_fileinfo->setText(QStringLiteral("写入excel完毕."));
    qsqldatabaseDB.close();

 

//  数据如下

688:FFFF010001000100
788:FFFF010001000100
794:FFFF010001000100

 

posted @   小城熊儿  阅读(66)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示