一文搞定Qt读写excel以及qt读写xml数据
生活随笔
收集整理的這篇文章主要介紹了
一文搞定Qt读写excel以及qt读写xml数据
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一文搞定Qt讀寫excel以及qt讀寫xml數據
最終的實現效果圖
.pro文件同級目錄下加入 logo.ico 圖標文件,運行文件,文件的圖標就被寫入軟件
ui首先拖幾個控件出來 lineEdit pushButton TextEdit label 等
命名就不在細說了
最后的打包語句是
C:\Users\Administrator\Desktop\test2>windeployqt DemoTest123.exe打包好,最后用 虛擬文件打包工具(Enigma Virtual Box)9.20漢化去廣告版 軟件壓縮整個類庫文件
點 pro文件添加的模塊是
xlsx 安裝模塊比較復雜,這里不細說,
用到 Perl 軟件 ,以及一個github的開源項目,編譯src文件,得到lib 類庫文件,include , modules等
全部復制到本地的安裝的Qt的文件目錄里面,最后測試一下,看看能不能寫出最簡單的一個xlsx文件出來,若能寫出來,則說明軟件的環境搭建成功!
如圖所示編譯的幾個文件或文件夾全部復制到本地的安裝目錄下,才能加入模塊,否則報錯,
github下載慢,請打開手機熱點下載會快一點,
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数据的全部內容,希望文章能夠幫你解決所遇到的問題。