日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

一文搞定Qt读写excel以及qt读写xml数据

發布時間:2023/12/18 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一文搞定Qt读写excel以及qt读写xml数据 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一文搞定Qt讀寫excel以及qt讀寫xml數據

最終的實現效果圖

RC_ICONS = logo.ico

.pro文件同級目錄下加入 logo.ico 圖標文件,運行文件,文件的圖標就被寫入軟件

ui首先拖幾個控件出來 lineEdit pushButton TextEdit label 等
命名就不在細說了

最后的打包語句是

C:\Users\Administrator\Desktop\test2>windeployqt DemoTest123.exe

打包好,最后用 虛擬文件打包工具(Enigma Virtual Box)9.20漢化去廣告版 軟件壓縮整個類庫文件
點 pro文件添加的模塊是

QT += core gui xlsx xmlRC_ICONS = logo.ico

xlsx 安裝模塊比較復雜,這里不細說,
用到 Perl 軟件 ,以及一個github的開源項目,編譯src文件,得到lib 類庫文件,include , modules等
全部復制到本地的安裝的Qt的文件目錄里面,最后測試一下,看看能不能寫出最簡單的一個xlsx文件出來,若能寫出來,則說明軟件的環境搭建成功!
如圖所示編譯的幾個文件或文件夾全部復制到本地的安裝目錄下,才能加入模塊,否則報錯,
github下載慢,請打開手機熱點下載會快一點,





widget.h文件的代碼

#ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QList> #include <QString>namespace Ui { class Widget; }class Widget : public QWidget {Q_OBJECTpublic:explicit Widget(QWidget *parent = 0);~Widget();private slots:void on_pushButton_clicked();void on_pushButton_2_clicked();private:Ui::Widget *ui;QList<QString> snList;void testBU(QList<QString> sn); };#endif // WIDGET_H

widget.cpp代碼是

#include "widget.h" #include "ui_widget.h" #include <QtXlsx> #include <QDebug> #include <QList> #include <QString> #include <QFile> #include <QtXml> #include <QCoreApplication> #include <QString> #include <QTime> #include <QMessageBox> #include <QFileDialog>Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget) {ui->setupUi(this);this->setWindowTitle("歡迎使用批量資料系統,針對xlsx文件設置Desgin By Jason [20200930]"); }Widget::~Widget() {delete ui; }void Widget::on_pushButton_clicked() {QString snPathName = ui->lineEdit->text();if(snPathName.isEmpty()){QMessageBox::warning(this,"提示","請選擇一個xlsx文件");return;}QString xlsx_name=snPathName.mid(snPathName.lastIndexOf('.')+1,snPathName.length()-1); //字符串的截取qDebug() << xlsx_name;if(xlsx_name=="xlsx"){QXlsx::Document xlsx(snPathName);QXlsx::Workbook *workBook = xlsx.workbook();QXlsx::Worksheet *workSheet = static_cast<QXlsx::Worksheet*>(workBook->sheet(0));ui->textEdit->setWordWrapMode(QTextOption::NoWrap);for(int i=2;i<=workSheet->dimension().rowCount();i++) {QXlsx::Cell *cell = workSheet->cellAt(i,1);if(cell==NULL) continue;QString sn = cell->value().toString();snList<<sn;ui->textEdit->append(QString("%1").arg(sn));}testBU(snList);QString strmsg = QString("共%1個SN資料成功!").arg(snList.count());QMessageBox::about(this,"提示",strmsg);}else{QMessageBox::warning(this,"提示","請選擇一個xlsx文件");return;} }void Widget::testBU(QList<QString> sn) {if(!sn.isEmpty()){QString str;QString file_name;int j=1;QFile file;for(int i=0;i<sn.size();++i){qDebug () << sn.at(i) << "===";// str = sn.at(i);file_name=QString("C:\\%1_system-764#1_012524.xml").arg(sn.at(i));QFile file(file_name);file.open(QIODevice::WriteOnly);QDomDocument doc;QDomProcessingInstruction instruction; //添加處理命令instruction=doc.createProcessingInstruction("xml","version=\"1.0\" encoding=\"UTF-8\"");doc.appendChild(instruction);//添加根節點QDomElement root=doc.createElement("ns1:XMLExport");root.setAttribute("xmlns:ns1","http://tempuri.org.xsd");root.setAttribute("numberOfIndictedComponents","0");doc.appendChild(root);//添加第一個子節點及其子元素QDomElement firstNode = doc.createElement("ns1:XML");firstNode.setAttribute("serialNumber",sn.at(i));root.appendChild(firstNode);QDomElement secNode=doc.createElement("ns1:StaXML");secNode.setAttribute("stage","");root.appendChild(secNode);QDomElement threeNode=doc.createElement("ns1:EventXML");threeNode.setAttribute("numberOfVariationOkComponents","0");threeNode.setAttribute("numberOfVariationOkPins","0");root.appendChild(threeNode);QTextStream out_stream(&file);doc.save(out_stream,4); //縮進4格}file.close();} }void Widget::on_pushButton_2_clicked() {QString fileName = QFileDialog::getOpenFileName(this,tr("open a file."),"C:/",tr("xlsx(*.xlsx *.xls);;images(*.png *jpeg *bmp);;video files(*.avi *.mp4 *.wmv);;All files(*.*)"));if (fileName.isEmpty()) {QMessageBox::warning(this, "Warning!", "Failed to open the xlsx file!");}else {ui->lineEdit->setText(fileName);} }

總結

以上是生活随笔為你收集整理的一文搞定Qt读写excel以及qt读写xml数据的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。