2014-04-11 21:29:15 -04:00
|
|
|
import pyqtgraph as pg
|
|
|
|
import numpy as np
|
2021-02-15 09:52:06 -08:00
|
|
|
from collections import OrderedDict
|
2014-04-11 21:29:15 -04:00
|
|
|
|
|
|
|
app = pg.mkQApp()
|
|
|
|
|
|
|
|
|
2014-04-12 11:54:23 -04:00
|
|
|
listOfTuples = [('text_%d' % i, i, i/9.) for i in range(12)]
|
2014-04-11 21:29:15 -04:00
|
|
|
listOfLists = [list(row) for row in listOfTuples]
|
|
|
|
plainArray = np.array(listOfLists, dtype=object)
|
|
|
|
recordArray = np.array(listOfTuples, dtype=[('string', object),
|
|
|
|
('integer', int),
|
|
|
|
('floating', float)])
|
|
|
|
dictOfLists = OrderedDict([(name, list(recordArray[name])) for name in recordArray.dtype.names])
|
|
|
|
listOfDicts = [OrderedDict([(name, rec[name]) for name in recordArray.dtype.names]) for rec in recordArray]
|
|
|
|
transposed = [[row[col] for row in listOfTuples] for col in range(len(listOfTuples[0]))]
|
|
|
|
|
|
|
|
def assertTableData(table, data):
|
|
|
|
assert len(data) == table.rowCount()
|
|
|
|
rows = list(range(table.rowCount()))
|
|
|
|
columns = list(range(table.columnCount()))
|
|
|
|
for r in rows:
|
|
|
|
assert len(data[r]) == table.columnCount()
|
|
|
|
row = []
|
|
|
|
for c in columns:
|
|
|
|
item = table.item(r, c)
|
|
|
|
if item is not None:
|
|
|
|
row.append(item.value)
|
|
|
|
else:
|
|
|
|
row.append(None)
|
|
|
|
assert row == list(data[r])
|
|
|
|
|
|
|
|
|
|
|
|
def test_TableWidget():
|
|
|
|
w = pg.TableWidget(sortable=False)
|
|
|
|
|
|
|
|
# Test all input data types
|
|
|
|
w.setData(listOfTuples)
|
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
|
|
|
w.setData(listOfLists)
|
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
|
|
|
w.setData(plainArray)
|
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
|
|
|
w.setData(recordArray)
|
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
|
|
|
w.setData(dictOfLists)
|
|
|
|
assertTableData(w, transposed)
|
|
|
|
|
|
|
|
w.appendData(dictOfLists)
|
|
|
|
assertTableData(w, transposed * 2)
|
|
|
|
|
|
|
|
w.setData(listOfDicts)
|
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
|
|
|
w.appendData(listOfDicts)
|
|
|
|
assertTableData(w, listOfTuples * 2)
|
|
|
|
|
|
|
|
# Test sorting
|
|
|
|
w.setData(listOfTuples)
|
2021-06-05 18:17:43 -07:00
|
|
|
w.sortByColumn(0, pg.QtCore.Qt.SortOrder.AscendingOrder)
|
2014-04-11 21:29:15 -04:00
|
|
|
assertTableData(w, sorted(listOfTuples, key=lambda a: a[0]))
|
|
|
|
|
2021-06-05 18:17:43 -07:00
|
|
|
w.sortByColumn(1, pg.QtCore.Qt.SortOrder.AscendingOrder)
|
2014-04-11 21:29:15 -04:00
|
|
|
assertTableData(w, sorted(listOfTuples, key=lambda a: a[1]))
|
|
|
|
|
2021-06-05 18:17:43 -07:00
|
|
|
w.sortByColumn(2, pg.QtCore.Qt.SortOrder.AscendingOrder)
|
2014-04-11 21:29:15 -04:00
|
|
|
assertTableData(w, sorted(listOfTuples, key=lambda a: a[2]))
|
|
|
|
|
|
|
|
w.setSortMode(1, 'text')
|
2021-06-05 18:17:43 -07:00
|
|
|
w.sortByColumn(1, pg.QtCore.Qt.SortOrder.AscendingOrder)
|
2014-04-11 21:29:15 -04:00
|
|
|
assertTableData(w, sorted(listOfTuples, key=lambda a: str(a[1])))
|
|
|
|
|
|
|
|
w.setSortMode(1, 'index')
|
2021-06-05 18:17:43 -07:00
|
|
|
w.sortByColumn(1, pg.QtCore.Qt.SortOrder.AscendingOrder)
|
2014-04-11 21:29:15 -04:00
|
|
|
assertTableData(w, listOfTuples)
|
|
|
|
|
2014-04-12 11:54:23 -04:00
|
|
|
# Test formatting
|
|
|
|
item = w.item(0, 2)
|
|
|
|
assert item.text() == ('%0.3g' % item.value)
|
|
|
|
|
|
|
|
w.setFormat('%0.6f')
|
|
|
|
assert item.text() == ('%0.6f' % item.value)
|
|
|
|
|
|
|
|
w.setFormat('X%0.7f', column=2)
|
|
|
|
assert isinstance(item.value, float)
|
|
|
|
assert item.text() == ('X%0.7f' % item.value)
|
|
|
|
|
|
|
|
# test setting items that do not exist yet
|
|
|
|
w.setFormat('X%0.7f', column=3)
|
|
|
|
|
|
|
|
# test append uses correct formatting
|
|
|
|
w.appendRow(('x', 10, 7.3))
|
|
|
|
item = w.item(w.rowCount()-1, 2)
|
|
|
|
assert isinstance(item.value, float)
|
|
|
|
assert item.text() == ('X%0.7f' % item.value)
|
|
|
|
|
|
|
|
# test reset back to defaults
|
|
|
|
w.setFormat(None, column=2)
|
|
|
|
assert isinstance(item.value, float)
|
|
|
|
assert item.text() == ('%0.6f' % item.value)
|
|
|
|
|
|
|
|
w.setFormat(None)
|
|
|
|
assert isinstance(item.value, float)
|
|
|
|
assert item.text() == ('%0.3g' % item.value)
|
|
|
|
|
|
|
|
# test function formatter
|
|
|
|
def fmt(item):
|
|
|
|
if isinstance(item.value, float):
|
|
|
|
return "%d %f" % (item.index, item.value)
|
|
|
|
else:
|
|
|
|
return pg.asUnicode(item.value)
|
|
|
|
w.setFormat(fmt)
|
|
|
|
assert isinstance(item.value, float)
|
|
|
|
assert isinstance(item.index, int)
|
|
|
|
assert item.text() == ("%d %f" % (item.index, item.value))
|