- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我编写了一个 gui 程序,它将连接到 oracle 数据库并在键入查询后检索数据。检索到的数据显示在 QTableView 表模型小部件中。然后将 QTableView 的结果导出到 .csv 文件
QString MyQuery = ui->lineQuery->text();
db.open();
QSqlQuery query(MyQuery,db);
if(query.exec())
{
qDebug()<<QDateTime::currentDateTime()<<"QUERY SUCCESS ";
ui->queryButton->setStyleSheet("QPushButton {background-color: rgb(0, 255, 0);}");
this->model=new QSqlQueryModel();
model->setQuery(MyQuery);
ui->tableViewOra->setModel(model);
QString textData;
int rows=model->rowCount();
int columns=model->columnCount();
for (int i = 0; i < rows; i++)
{
for (int j = 0; j < columns; j++)
{
textData += model->data(model->index(i,j)).toString();
textData += ", "; // for .csv file format
}
textData += "\n"; // (optional: for new line segmentation)
}
QFile csvfile("/home/aj/ora_exported.csv");
if(csvfile.open(QIODevice::WriteOnly|QIODevice::Truncate))
{
QTextStream out(&csvfile);
out<<textData;
}
csvfile.close();
}
现在的问题是,在查询期间,我观察到 QTableView 中有 543 行可见(这是正确的,因为有 543 个条目)。但是当导出 .csv 文件时,那里只有 256 行。
是否有任何我不知道的可变大小限制???
如果我想导出大约 1000 行的 .csv 文件,应该注意哪些变量???谢谢。
最佳答案
我认为当您第一次阅读 model->rowCount()
时,模型并没有完全获取所有结果。尽管稍后在显示 TableView 时会获取更多内容,从而在 TableView 中完整显示行。
在读取行数之前尝试使用QSqlQueryModel::fetchMore
:
while (model->canFetchMore())
model->fetchMore();
int rows=model->rowCount();
int columns=model->columnCount();
[来自 Tay2510 的附加信息]:
你可以改变文件打开标志
if(csvfile.open(QIODevice::WriteOnly|QIODevice::Truncate))
到
if(csvfile.open(QIODevice::WriteOnly))
前者将覆盖同一个文件,而后者附加数据。
关于c++ - QTableView 导出到 .csv 的行数仅限于 256,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27372078/
我正在使用 Qtableview与 QsqlTableModel用于填充表数据。我想根据用户对列标题的选择对列进行排序。 我尝试了QTableView sorting signal?中提到的方法用于获
我试图在 python 中找到一个示例,在其中我可以循环 QTableView 的模型元素并打印整行。我已经找到了如何循环选定的行,但在未选择行时什么也没有。 有人可以帮助我吗?无需告诉我如何创建模型
我正在尝试将 QTableView 中的水平和垂直标题设置为自动换行,但没有任何成功。 我想将所有列设置为相同的宽度(包括垂直标题),以及那些多行文本要自动换行的列。如果单词比列宽,它应该向右省略。
我使用 QTableView 和 QAbstractTableModel 的子类作为它的模型。 我看到(默认情况下)当用户输入内容时,QTableView 开始搜索第一列中输入的文本并将 View 滚
实际上我是 Qt 新手,无法匹配 QMouseEvent与 QTableview 请帮助解决这个问题。 最佳答案 以下是单击表格单元格文本时如何获取表格单元格文本的示例。 假设一个 QTableVie
我有一个 QTableView我需要从中获取 selectionChanged 事件。我似乎无法连接工作。我有: MyWidget.h ... protected slots: void slotL
当用户在 QTableView 中选择一行时是否会发出信号?通过鼠标(单选模型)? 最佳答案 每个 View 都有一个选择模型: QItemSelectionModel * QAbstractItem
我正在使用 QTableView与 QAbstractTableModel和 QSortFilterProxyModel这样我就可以通过单击表格标题对项目进行排序。我想为用户添加选项,通过拖动它们来手
是否可以对 QTableView 的标题进行排序? 我想对水平和垂直标题进行排序。 QTableView 仅提供对列内容进行排序的功能。有没有办法对 View 进行排序,或者我是否必须对底层数据结构进
我对 QT 还很陌生,无法理解 QTableView选择改变信号被处理。我已经设置了一个带有 openGL 小部件和 QTableView 的窗口.我有一个正确填充表格 View 的数据模型类,因此我
我是 qt 的新手,我在 QTtableview 中使用 QStandardItemModel。 请建议, 如何更改行和列标题名称。目前它显示 1,2,3,4 如何让 QStandardItemMod
使用 QTableView和 QAbstractTableModel - 当模型发出 dataChanged对于正在编辑的单元格的事件,用户在单元格中键入的字符串(但未按 Enter 以“提交”编辑)
我有一个带有数据的 QTableView。添加行的最简单方法是什么? 谢谢! 最佳答案 当您使用 som YourModel 在 YourTableView (QTableView) 中显示它时,应该
我正在尝试创建一个可以像在 Excel 中一样放大和缩小的 QTableView。 此处提出了类似的问题:Zooming function on a QWidget 但是,我在 PyQt 而不是 C
我正在尝试在 QTableView 中实现类似于 Excel 的行为,其中在整个当前选择周围绘制了一个边框。我已经尝试过这种感觉就像一百种不同的方法并且不断遇到问题。我可以很容易地绘制边框,但是只要选
我正在写一个简单的 TableView根据 http://harmattan-dev.nokia.com/docs/library/html/qt4/itemviews-addressbook.htm
我有一个基于 QStandardItemModel 的 QTableView。我想将第一列设置为“只读”,将所有其他列设置为可编辑。 我不是 QT 和 OOP 的专家,我在网上和 QT 文档中进行了搜
我有两个相同的 QTableView,其中一个是可排序的。这两个表的最后四列的调整模式设置为 QHeaderView::ResizeToContents。 不可排序的表格列宽看起来是正确的,列标题的左
我在 Sqlite 数据库中有一个表,我使用 QTableview 和 QSqlQueryModel 显示它。第一列需要有一个标题,它是一个复选框,列中的所有项目也需要是复选框。我已将第一列标题实现为
我想在 QTableView 中实现用户可编辑复选框这是使用 QAbstractModel 创建的。我可以分配选中和未选中的复选框,但无法使其可编辑。 标志设置为 QItemIsUserCheckab
我是一名优秀的程序员,十分优秀!