QHeaderView::Interactive 0 The user can resize the section. The section can also be resized programmatically using resizeSection ()
QHeaderView::Fixed 2 The user cannot resize the section. The section can only be resized programmatically using resizeSection ()
QHeaderView::Stretch 1 will automatically resize the section to fill the available space. The size cannot be changed by the user or programmatically
QHeaderView::ResizeToContents 3 will automatically resize the section to its optimal size based on the contents of the entire column or row. The size cannot be changed by the user or programmatically
self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch) // 列宽自动分配
self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Interactive) // 交互调整
self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Fixed) // 固定值
self.tableWidget.setColumnWidth(0, 40)
self.tableWidget.setColumnWidth(1, 200)
self.tableWidget.setColumnWidth(2, 200)
// 可以两种方式结合用
self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
self.tableWidget.horizontalHeader().setSectionResizeMode(0, HeaderView.ResizeToContents)
// 使第一列自动匹配内容
self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
self.tableWidget.horizontalHeader().setSectionResizeMode(0, QHeaderView.Interactive)
// 除最后一列随边框变化外,其余宽度不能改变
qcdataTable->horizontalHeader()->setResizeMode(QHeaderView::Fixed);
qcdataTable->horizontalHeader()->setStretchLastSection(true);
// 设置tableWidget所有列的默认行高为20。
self.tableWidget.verticalHeader()->setDefaultSectionSize(20)
// 设置tableWidget所有行的默认列宽为20
self.tableWidget.horizontalHeader()->setDefaultSectionSize(20)可以
// QTableWidget设置整行选中
self.tableWidget.setSelectionBehavior(QAbstractItemView.SelectRows);
self.tableWidget.setSelectionMode(QAbstractItemView.SingleSelection);