QTableWidget 导出到csv表格
跳槽到了新的公司,开始苦逼的出差现场开发,接触到了新的应用。有很多应用需要将Table导出成表格,可以把table导出成csv格式的文件。跟大伙分享一下;
- lass TableToExcle : public QDialog
- {
- Q_OBJECT
- public:
- TableToExcle(QWidget *parent = 0, Qt::WFlags flags = 0);
- ~TableToExcle();
- private:
- Ui::TableToExcleClass ui;
- private slots:
- void addRowSlot();
- void delRowSlot();
- void exportSlot();
- };
- TableToExcle::TableToExcle(QWidget *parent, Qt::WFlags flags)
- : QDialog(parent, flags)
- {
- ui.setupUi(this);
- ui.m_pTable->setColumnCount(4);
- QTableWidgetItem * item = new QTableWidgetItem("0");
- ui.m_pTable->setHorizontalHeaderItem ( 0, item );
- item = new QTableWidgetItem("1");
- ui.m_pTable->setHorizontalHeaderItem ( 1, item );
- item = new QTableWidgetItem("2");
- ui.m_pTable->setHorizontalHeaderItem ( 2, item );
- item = new QTableWidgetItem("3");
- ui.m_pTable->setHorizontalHeaderItem ( 3, item );
- ui.m_pTable->setSelectionBehavior(QAbstractItemView::SelectRows);
- connect(ui.m_pAddBtn,SIGNAL(clicked()),this,SLOT(addRowSlot()));
- connect(ui.m_pDelBtn,SIGNAL(clicked()),this,SLOT(delRowSlot()));
- connect(ui.m_pExportBtn,SIGNAL(clicked()),this,SLOT(exportSlot()));
- }
- TableToExcle::~TableToExcle()
- {
- }
- void TableToExcle::addRowSlot()
- {
- ui.m_pTable->insertRow(ui.m_pTable->rowCount());
- }
- void TableToExcle::delRowSlot()
- {
- int index = ui.m_pTable->currentRow ();
- if (index > -1)
- {
- ui.m_pTable->removeRow(index);
- }
- }
- void TableToExcle::exportSlot()
- {
- QString fileName = QFileDialog::getSaveFileName(this, tr("Save File")," ",tr("file (*.csv)"));
- if (!fileName.isEmpty())
- {
- QFile file(fileName);
- bool ret = file.open( QIODevice::Truncate | QIODevice::WriteOnly);
- if(!ret)
- return;
- QTextStream stream(&file);
- QString conTents;
- QHeaderView * header = ui.m_pTable->horizontalHeader() ;
- if (header)
- {
- for ( int i = 0; i < header->count(); i++ )
- {
- QTableWidgetItem *item = ui.m_pTable->horizontalHeaderItem(i);
- if (!item)
- {
- continue;
- }
- conTents += item->text() + ",";
- }
- conTents += "\n";
- }
- for ( int i = 0 ; i < ui.m_pTable->rowCount(); i++ )
- {
- for ( int j = 0; j < ui.m_pTable->columnCount(); j++ )
- {
- QTableWidgetItem* item = ui.m_pTable->item(i, j);
- if ( !item )
- continue;
- QString str = item->text();
- str.replace(","," ");
- conTents += str + ",";
- }
- conTents += "\n";
- }
- stream << conTents;
- file.close();
- }
- if( QMessageBox::Yes == QMessageBox::information(0,QObject::tr("文件导出"),QString("文件导出成功,是否打开该文件?"),QMessageBox::Yes,QMessageBox::No) )
- {
- QSettings settings("HKEY_LOCAL_MACHINE\\Software\\Microsoft\\Office",QSettings::NativeFormat);
- QString szDefault, szPath;
- bool bSuccess;
- szPath = settings.value("12.0/Excel/InstallRoot/Path").toString();
- if (szPath.isEmpty())
- szPath = settings.value("11.0/Excel/InstallRoot/Path").toString();
- if (szPath.isEmpty())
- szPath = settings.value("10.0/Excel/InstallRoot/Path").toString();
- if (szPath.isEmpty())
- szPath = settings.value("9.0/Excel/InstallRoot/Path").toString();
- if (szPath.isEmpty())
- szPath = settings.value("14.0/Excel/InstallRoot/Path").toString();
- if (szPath.isEmpty())
- {
- QMessageBox::information(0, "提示", "系统没有安装Office, 不能查看故障报告,请您先安装Microsoft Office.");
- return;
- }
- QProcess * proce = new QProcess;
- QString szExcelexe = szPath + "excel.exe";
- QString szopen = "/safe";
- QString szDoc = fileName;
- QStringList list;
- list<<szDoc;
- if( proce )
- {
- proce->start(szExcelexe,list);
- proce->waitForStarted(5000); //需要等待完成启动
- }<pre name="code" class="cpp"> delete proce;
http://blog.csdn.net/hai200501019/article/details/37538591
QTableWidget 导出到csv表格的更多相关文章
- 实现数据导出为.csv表格
数据导出实现步骤: 1.查找出要导出的数据,整理为二维数组. 2.定义导出表格的字段 3.将整理的二维数组按导出表格定义的字段重新整理. 4.将整理的二维数组写入服务器中已有的一个.csv文件. 5. ...
- csv表格处理(上)-- JS 与 PHP 协作导入导出
CSV简介 在开发后台管理系统的时候,几乎无可避免的会遇到需要导入导出Excel表格的需求.csv也是表格的一种,其中文名为“逗号分隔符文件”.在Excel中打开如下图左边所示,在记事本打开如下图右边 ...
- QTableWidget 导出到表格
跳槽到了新的公司.開始苦逼的出差现场开发.接触到了新的应用.有非常多应用须要将Table导出成表格,能够把table导出成csv格式的文件. 跟大伙分享一下: lass TableToExcle : ...
- csv表格处理(下)--纯JS解析导入csv
多日前的上篇介绍了csv表格,以及JS结合后端PHP解析表格填充表单的方法.其中csv转换成二维数组的时候逻辑比较复杂多坑,幸好PHP有丰富的库函数来处理,而现在用JS解析的话就没有那么幸运了,一切都 ...
- PHP处理CSV表格文件的常用操作方法是怎么样呢
php来说,fgetcsv读入csv表格,返回一个数组,然后foreach输出成HTML的<table>,这步操作几行代码就能实现,非常简单.工作量主要还在于浏览器前端,建议你用jQuer ...
- PHP 高效导入导出Excel(csv)方法之fgetcsv()和fputcsv()函数
CSV,是Comma Separated Value(逗号分隔值)的英文缩写,通常都是纯文本文件. 一.CSV数据导入函数fgetcsv() fgetcsv() 函数从文件指针中读入一行并解析 CSV ...
- 十七 bootstrap-table tableExport 导出xlsx格式表格
原文:十七 bootstrap-table tableExport 导出xlsx格式表格 在[十六.bootstrap-table javascript导出数据]中,打开导出的表格时,总会弹出一个提示 ...
- 将mysql数据库的数据导出做成excl表格通过邮件发送附件发给指定人
mysql数据库的数据导出成excl表 方法一: mysql -uroot -p123456 -e “select *.* from 表 into outfile ‘文件路径.xls’into out ...
- CSV表格读取
读取CSV表格需要CSV表格的编码格式为UTF-8 ,这个脚本中有些是为了方便使用封装的dll 不过都是一些简单的实现,自己实现也很容易,可做参考. /// <summary> /// 构 ...
随机推荐
- Java基础--finalize()方法
原理: 一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法,并在下一次垃圾回收动作发生时,才会真正回收对象占用的内存. 用途: 1)释放通过某种创建对象方式以外的方式为对 ...
- floyed算法
Floyed算法(实际是动态规划问题) 问题:权值矩阵matrix[i][j]表示i到j的距离,如果没有路径则为无穷 求出权值矩阵中任意两点间的最短距离 分析:对于每一对定点u,v看是否存在一个点w使 ...
- Xcode 新版本如何设置ARC
在刚刚开始学习IOS开发时,最好不要开启ARC,这样有助于学习内存管理,但不少刚刚接触Xcode的朋友可能会发现,当你使用最新版本的Xcode时,敲入release等代码时会提示报错.这是因为系统默认 ...
- oracle去除字符串中间的空格
update AC01 A set A.AAC003 = REGEXP_REPLACE(A.AAC003, '( ){1,}', '') WHERE A.AAC002 IN (SELECT AAC00 ...
- HYSBZ 2301
/*** 对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数 **/ #include <iost ...
- 198,House Robber
一.题目 You are a professional robber planning to rob houses along a street. Each house has a certain a ...
- 菜鸟系列之C/C++经典试题(七)
找含单链表的环入口点 :怎样推断单链表中是否存在环(即下图中从结点E到结点R组成的环)? ,则在low进入环后继续绕环遍历一周之前fast必定能与low重合(且必定是第一次重合).于是函数可写例如以下 ...
- POJ 3667 splay区间盘整运动
Hotel Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 12446 Accepted: 5363 Descriptio ...
- android -- 蓝牙 bluetooth (四)OPP文件传输
在前面android -- 蓝牙 bluetooth (一) 入门文章结尾中提到了会按四个方面来写这系列的文章,前面已写了蓝牙打开和蓝牙搜索,这次一起来看下蓝牙文件分享的流程,也就是蓝牙应用opp目录 ...
- CSS的三种样式:内联式,嵌入式,外部式以及他们的优先级
从CSS 样式代码插入的形式来看基本能够分为下面3种:内联式.嵌入式和外部式三种. 1:内联式css样式表就是把css代码直接写在现有的HTML标签中,如以下代码: <p style=" ...