一文搞定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数据相关推荐

  1. 一文搞定C#关于NPOI类库的使用读写Excel以及io流文件的写出

    一文搞定C#关于NPOI类库的使用读写Excel以及io流文件的写出 今天我们使用NPOI类库读写xlsx文件, 最终实现的效果如图所示 从太平洋官网下载相应的类库,大概4~5MB,不要从github ...

  2. 一文搞定Swing和Qt按钮和文本框的创建

    一文搞定Swing和Qt按钮和文本框的创建 Qt的截图 java的 源码 package com.lujun;import java.awt.Container;import javax.swing. ...

  3. 【量化交易行情不够快?】一文搞定通过Win10 wsl2 +Ubuntu+redis+pickle实现股票行情极速读写

    一文搞定通过Win10 wsl2 +Ubuntu+redis+pickle实现股票行情极速读写 前言 一.准备环境分四步 1.1 给Win10装wsl2 硬件开启虚拟化 软件开启虚拟化及安装适用于Li ...

  4. 一文搞定 Spring Data Redis 详解及实战

    转载自  一文搞定 Spring Data Redis 详解及实战 SDR - Spring Data Redis的简称. Spring Data Redis提供了从Spring应用程序轻松配置和访问 ...

  5. bootstraptable导出excel独立使用_JavaWeb系列之-一小时搞定POI导出Excel

    课程简介: 课程目标:通过本视频,可以在一小时之内快速实现使用Apache POI组件导出excel,您是不是项目中用到这个功能了,是不是懒得从网上查代码改代码呢?这个简短的小视频适合您. 适用人群: ...

  6. 一文搞定vim,从安装到入门到精通,助你成功入门vim

    一文搞定vim,从安装到入门到精通 NO.1 闲聊 NO.2 安装(不是重点!觉得这部分讲的不清楚可以去找一篇win下安装vim的文章来看,然后跳去NO.3接着看) NO3. 文章核心重点-vim使用 ...

  7. php带参数单元测试_一文搞定单元测试核心概念

    基础概念 单元测试(unittesting),是指对软件中的最小可测试单元进行检查和验证,这里的最小可测试单元通常是指函数或者类.单元测试是即所谓的白盒测试,一般由开发人员负责测试,因为开发人员知道被 ...

  8. 【Python基础】一文搞定pandas的数据合并

    作者:来源于读者投稿 出品:Python数据之道 一文搞定pandas的数据合并 在实际处理数据业务需求中,我们经常会遇到这样的需求:将多个表连接起来再进行数据的处理和分析,类似SQL中的连接查询功能 ...

  9. 一文搞定面试中的二叉树问题

    一文搞定面试中的二叉树问题 版权所有,转载请注明出处,谢谢! http://blog.csdn.net/walkinginthewind/article/details/7518888 树是一种比较重 ...

最新文章

  1. 环境搭建 - 奥比中光3D摄像头(Astra Mini)
  2. Annaconda下Python2.7路径
  3. matlab bs2rv.m,matlab遗传算法工具箱中的例子不能用?
  4. debian GNU linux 版的docker 安装vi
  5. java io-File
  6. 1.7 LINUX启动流程
  7. 2017 年,阿里巴巴开源的那些事儿
  8. php油酸诱导剂,油酸诱导建鲤(Cyprinus carpio var. Jian)肝细胞脂肪变性模型的建立
  9. 计算机软件开发外包合同范本,软件外包合同
  10. 项目管理:项目质量管理
  11. PLC扩展模块总线连接方式?IO扩展模块和主模块。西门子用到的总线中的一种背板总线简单介绍扩展模块中也有控制芯片(CPU)(或者类似SPI协议芯片),除了扩展模块(SM)还有扩展板(SB)
  12. linux申请令牌错误,解决“请求中包含的安全令牌已过期”错误
  13. Elasticsearch:Apache spark 大数据集成
  14. DDoS攻击、CC攻击
  15. 房产行业数字化转型迷思:技术能提供何种助力?
  16. java桌面端开发为什么没就行起来,大部分人选qt,winform,electron?
  17. 【渝粤题库】陕西师范大学202491 法语(一)作业
  18. Tensorflow目标检测之yolov3训练自己的模型
  19. linux系统做成iso镜像文件,如何在Linux系统中制作可启动img/iso镜像文件
  20. C/C++描述 LeetCode 167. 两数之和 II - 输入有序数组

热门文章

  1. jupyternotebook运行python_怎么运行jupyter notebook?
  2. mysql根据id删除数据sql语句_sql delete根据id删除数据库
  3. 全国一等奖,F题:智能送药小车。
  4. 我在STM32单片机上跑神经网络算法
  5. 耗时两年,19岁小伙采用230片纯74逻辑芯片搭建出32位Risc-V处理器!可玩贪吃蛇...
  6. 基于Nexys4 DDR的温度数码管实时显示
  7. cad画1000线太长了_为什么你画CAD图没别人快?今天就教你几招!
  8. 知了课堂 python_没想到你是这样的“知了课堂”
  9. figtree需要在JAVA下运行吗_Phylogenomic_Tutorial || ML_Tree inference
  10. python设置图片透明度_学习python第40天