QTableWidget 导出到csv表格

跳槽到了新的公司,开始苦逼的出差现场开发,接触到了新的应用。有很多应用需要将Table导出成表格,可以把table导出成csv格式的文件。跟大伙分享一下;

[cpp] view plain copy

  1. lass TableToExcle : public QDialog
  2. {
  3. Q_OBJECT
  4. public:
  5. TableToExcle(QWidget *parent = 0, Qt::WFlags flags = 0);
  6. ~TableToExcle();
  7. private:
  8. Ui::TableToExcleClass ui;
  9. private slots:
  10. void addRowSlot();
  11. void delRowSlot();
  12. void exportSlot();
  13. };

[cpp] view plain copy

  1. TableToExcle::TableToExcle(QWidget *parent, Qt::WFlags flags)
  2. : QDialog(parent, flags)
  3. {
  4. ui.setupUi(this);
  5. ui.m_pTable->setColumnCount(4);
  6. QTableWidgetItem * item = new QTableWidgetItem("0");
  7. ui.m_pTable->setHorizontalHeaderItem ( 0, item );
  8. item = new QTableWidgetItem("1");
  9. ui.m_pTable->setHorizontalHeaderItem ( 1, item );
  10. item = new QTableWidgetItem("2");
  11. ui.m_pTable->setHorizontalHeaderItem ( 2, item );
  12. item = new QTableWidgetItem("3");
  13. ui.m_pTable->setHorizontalHeaderItem ( 3, item );
  14. ui.m_pTable->setSelectionBehavior(QAbstractItemView::SelectRows);
  15. connect(ui.m_pAddBtn,SIGNAL(clicked()),this,SLOT(addRowSlot()));
  16. connect(ui.m_pDelBtn,SIGNAL(clicked()),this,SLOT(delRowSlot()));
  17. connect(ui.m_pExportBtn,SIGNAL(clicked()),this,SLOT(exportSlot()));
  18. }
  19. TableToExcle::~TableToExcle()
  20. {
  21. }
  22. void TableToExcle::addRowSlot()
  23. {
  24. ui.m_pTable->insertRow(ui.m_pTable->rowCount());
  25. }
  26. void TableToExcle::delRowSlot()
  27. {
  28. int index = ui.m_pTable->currentRow ();
  29. if (index > -1)
  30. {
  31. ui.m_pTable->removeRow(index);
  32. }
  33. }
  34. void TableToExcle::exportSlot()
  35. {
  36. QString fileName = QFileDialog::getSaveFileName(this, tr("Save File")," ",tr("file (*.csv)"));
  37. if (!fileName.isEmpty())
  38. {
  39. QFile file(fileName);
  40. bool ret = file.open( QIODevice::Truncate | QIODevice::WriteOnly);
  41. if(!ret)
  42. return;
  43. QTextStream stream(&file);
  44. QString conTents;
  45. QHeaderView * header = ui.m_pTable->horizontalHeader() ;
  46. if (header)
  47. {
  48. for ( int i = 0; i < header->count(); i++ )
  49. {
  50. QTableWidgetItem *item = ui.m_pTable->horizontalHeaderItem(i);
  51. if (!item)
  52. {
  53. continue;
  54. }
  55. conTents += item->text() + ",";
  56. }
  57. conTents += "\n";
  58. }
  59. for ( int i = 0 ; i < ui.m_pTable->rowCount(); i++ )
  60. {
  61. for ( int j = 0; j < ui.m_pTable->columnCount(); j++ )
  62. {
  63. QTableWidgetItem* item = ui.m_pTable->item(i, j);
  64. if ( !item )
  65. continue;
  66. QString str = item->text();
  67. str.replace(","," ");
  68. conTents += str + ",";
  69. }
  70. conTents += "\n";
  71. }
  72. stream << conTents;
  73. file.close();
  74. }
  75. if( QMessageBox::Yes == QMessageBox::information(0,QObject::tr("文件导出"),QString("文件导出成功,是否打开该文件?"),QMessageBox::Yes,QMessageBox::No) )
  76. {
  77. QSettings settings("HKEY_LOCAL_MACHINE\\Software\\Microsoft\\Office",QSettings::NativeFormat);
  78. QString szDefault, szPath;
  79. bool bSuccess;
  80. szPath = settings.value("12.0/Excel/InstallRoot/Path").toString();
  81. if (szPath.isEmpty())
  82. szPath = settings.value("11.0/Excel/InstallRoot/Path").toString();
  83. if (szPath.isEmpty())
  84. szPath = settings.value("10.0/Excel/InstallRoot/Path").toString();
  85. if (szPath.isEmpty())
  86. szPath = settings.value("9.0/Excel/InstallRoot/Path").toString();
  87. if (szPath.isEmpty())
  88. szPath = settings.value("14.0/Excel/InstallRoot/Path").toString();
  89. if (szPath.isEmpty())
  90. {
  91. QMessageBox::information(0, "提示", "系统没有安装Office, 不能查看故障报告,请您先安装Microsoft Office.");
  92. return;
  93. }
  94. QProcess * proce = new QProcess;
  95. QString szExcelexe = szPath + "excel.exe";
  96. QString szopen = "/safe";
  97. QString szDoc = fileName;
  98. QStringList list;
  99. list<<szDoc;
  100. if( proce )
  101. {
  102. proce->start(szExcelexe,list);
  103. proce->waitForStarted(5000);        //需要等待完成启动
  104. }<pre name="code" class="cpp">               delete proce;

http://blog.csdn.net/hai200501019/article/details/37538591

时间: 2024-10-22 00:41:53

QTableWidget 导出到csv表格的相关文章

QTableWidget 导出到表格

跳槽到了新的公司,开始苦逼的出差现场开发,接触到了新的应用.有很多应用需要将Table导出成表格,可以把table导出成csv格式的文件.跟大伙分享一下: lass TableToExcle : public QDialog { Q_OBJECT public: TableToExcle(QWidget *parent = 0, Qt::WFlags flags = 0); ~TableToExcle(); private: Ui::TableToExcleClass ui; private s

PHP 和 JS 导入导出csv表格(上)

CSV简介 在开发后台管理系统的时候,几乎无可避免的会遇到需要导入导出Excel表格的需求.csv也是表格的一种,其中文名为"逗号分隔符文件".在Excel中打开如下图左边所示,在记事本打开如下图右边所示: 再看包含特殊字符的表格 与xls或xlsx 表格相类似,CSV文件也是用来表示二维表格.而不同的是: 1.CSV是一种纯文本文件,任何编辑器都能打开并读取它:xls(x)是专用的二进制文件,要用表格软件才能正常打开,否则乱码: 2.CSV的体积很小,比如上面的表格内容,csv只有几

Magento 对csv表格的导入功能 高级自定义部分!

magento自己带有导入导出功能 后台system-->import/export-->Advanced Profiles 进入后点击add new profiles 就可以新建一个规则了 Profile Name *是名字 Actions XML *是对应的参数 譬如例子: <action type="dataflow/convert_adapter_io" method="load"> <var name="type&q

csv表格处理(下)--纯JS解析导入csv

多日前的上篇介绍了csv表格,以及JS结合后端PHP解析表格填充表单的方法.其中csv转换成二维数组的时候逻辑比较复杂多坑,幸好PHP有丰富的库函数来处理,而现在用JS解析的话就没有那么幸运了,一切都要自己撸一个出来 或者 →_→ 引入一个库. JS导入CSV--读取文本 JS能前端读取文件吗?以前只有通过 IE的ActiveXObject或者Flash才能本地读取文件.随着H5的出现,这个问题有普遍解了.Talk is cheap,show you the code $.fn.csv2arr

PHP 高效导入导出Excel(csv)方法之fgetcsv()和fputcsv()函数

CSV,是Comma Separated Value(逗号分隔值)的英文缩写,通常都是纯文本文件. 一.CSV数据导入函数fgetcsv() fgetcsv() 函数从文件指针中读入一行并解析 CSV 字段. 与 fgets() 类似,不同的是 fgetcsv() 解析读入的行并找出 CSV 格式的字段,然后返回一个包含这些字段的数组. fgetcsv() 出错时返回 FALSE,包括碰到文件结束时. 具体使用时封装函数如下: /** * 导入Excel数据表格 * @param string

goalng导出excel(csv格式)

最近项目中有个小需求,需要将查询结果导出到excel.之间前java比较容易,使用POI很容易就能实现,查了下golang的文档,发现golang下边并没有导出excel的包,但是却有一个encoding/csv的包,看了下发现可以导出csv文件,大家都知道csv文件其实就是文本格式的excel文件,可以直接通过excel打开或是导入excel. 看起来挺好的,问题如愿解决,但是事实证明对已一个还不成熟的语言或是库最好还是先测一下的好.兴冲冲的卸了测试例子,成功导出了一个text.csv文件,一

oracle导出多CSV文件的靠谱的

oracle导出多CSV文件的问题 ---------------------------------------------------------------------- 用ksh脚本从oracle数据库中导出80w数据到csv文件,如用户给定名字为a.csv(文件最大4000行记录),则自动生产文件为a_1.csv,a_2.csv,...., a_200.csv 我已经实现了一个方法,但80w要导5小时,用户没法接受.如下: sqlplus -s user/pwd @${SqlDir}/

Asp.net--GridView控件--(1)高亮显示当前所在行,(2)高亮显示单击行,(3)绑定数据库数据,(4)分页,(5)导出到excel表格,(6)首列插入序号

//本页代码中的DB类及方法在http://www.cnblogs.com/Deerjiadelu/p/7252769.html中能查询到 (1)Asp.net--GridView控件--高亮显示当前所在行 protected void gvquery_DataBound(object sender, GridViewRowEventArgs e) { //高亮显示光标所在行 if (e.Row.RowType == DataControlRowType.DataRow)//判断当前行是不是数据

freemarker导出word——让表格数据行数 列数自动变化

行数.列数变化只需定义一个List<List<T>> freemarker遍历的话,只需要使用freemarker的标记性语言<#list report.qc_third_agentTable as  table2_tr>遍历即可,如图 实现的效果 freemarker导出word--让表格数据行数 列数自动变化,布布扣,bubuko.com