本组件的初衷就是造一个轮子,让数据导入导出用法极致简单,几个行数几行代码搞定它,适用大部分的应用场景,这也是本组件和qtxls最大的区别,qtxls的目标是大而全,提供各种xls的接口,至于如何组织导出的数据,那需要程序员自己去处理,这就避免不了需要调用很多函数代码,而我们往往入门的程序员用起来没那么方便,比如很多人其实就想将现在QTableWidget或者QTableView中的数据导出,也不想去研究如何组织数据,希望就是传入QTableWidget控件名称就行,什么字段名称、字段宽度、数据内容啥的,都不用管,因为控件都给你了,数据都在,具体实现函数去把它搞定就行,只要用的舒心舒服就好。
void frmSimple::on_btnLoad1_clicked() { //先设置数据模型,否则 setColumnWidth 不起作用 ui->tableView->setModel(model); //设置列数及列标题和列宽 model->setColumnCount(column); //简便方法设置列标题集合 model->setHorizontalHeaderLabels(columnNames); for (int i = 0; i < column; ++i) { ui->tableView->setColumnWidth(i, columnWidths.at(i)); } //循环添加行数据 QDateTime now = QDateTime::currentDateTime(); model->setRowCount(row); for (int i = 0; i < row; ++i) { for (int j = 0; j < column; ++j) { QStandardItem *item = new QStandardItem; //最后一列显示时间区别开来 if (j == column - 1) { item->setText(now.addSecs(i).toString("yyyy-MM-dd HH:mm:ss")); } else { item->setText(QString("%1_%2").arg(i + 1).arg(j + 1)); } model->setItem(i, j, item); } } } void frmSimple::on_btnCsv1_clicked() { QString file = QUIHelper::appPath() + "/db/dataout_tableview.csv"; DataHelper::DataOut(ui->tableView, model, 0, file, "测试标题", "测试信息"); //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnXls1_clicked() { //通用函数直接传入控件 #if 1 QString file = QUIHelper::appPath() + "/db/dataout_tableview.xls"; DataHelper::DataOut(ui->tableView, model, 1, file, "测试标题", "测试信息"); #else //不传入文件名则会弹出对话框选择保存文件名 QString file = DataHelper::DataOut(ui->tableView, model, 1); #endif //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnPdf1_clicked() { //通用函数直接传入控件 QString file = QUIHelper::appPath() + "/db/dataout_tableview.pdf"; DataHelper::DataOut(ui->tableView, model, 2, file, "测试标题", "测试信息"); //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnPrint1_clicked() { //通用函数直接传入控件 DataHelper::DataOut(ui->tableView, model, 3, "", "测试标题"); } void frmSimple::on_btnLoad2_clicked() { //设置列标题和列数及列宽 ui->tableWidget->setColumnCount(column); //简便方法设置列标题集合 ui->tableWidget->setHorizontalHeaderLabels(columnNames); for (int i = 0; i < column; ++i) { ui->tableWidget->setColumnWidth(i, columnWidths.at(i)); } //添加数据 QDateTime now = QDateTime::currentDateTime(); ui->tableWidget->setRowCount(row); for (int i = 0; i < row; ++i) { for (int j = 0; j < column; ++j) { QTableWidgetItem *item = new QTableWidgetItem; //最后一列显示时间区别开来 if (j == column - 1) { item->setText(now.addSecs(i).toString("yyyy-MM-dd HH:mm:ss")); } else { item->setText(QString("%1_%2").arg(i + 1).arg(j + 1)); } ui->tableWidget->setItem(i, j, item); } } } void frmSimple::on_btnCsv2_clicked() { QString file = QUIHelper::appPath() + "/db/dataout_tablewidget.csv"; DataHelper::DataOut(ui->tableWidget, 0, file, "测试标题", "测试信息"); //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnXls2_clicked() { QString file = QUIHelper::appPath() + "/db/dataout_tablewidget.xls"; DataHelper::DataOut(ui->tableWidget, 1, file, "测试标题", "测试信息"); //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnPdf2_clicked() { //通用函数直接传入控件 QString file = QUIHelper::appPath() + "/db/dataout_tablewidget.pdf"; DataHelper::DataOut(ui->tableWidget, 2, file, "测试标题", "测试信息"); //打开刚才导出的文件 QUIHelper::openFile(file, "导出测试信息"); } void frmSimple::on_btnPrint2_clicked() { //通用函数直接传入控件 DataHelper::DataOut(ui->tableWidget, 3, "", "测试标题"); }