[bugfix] WIP, creating new issue: Could not save project after initializing Event table; PySide2.QTableWidgetItem cannot be pickled!
This commit is contained in:
parent
de11c3b611
commit
aa73bb0ae8
58
PyLoT.py
58
PyLoT.py
@ -29,6 +29,7 @@ import os
|
|||||||
import platform
|
import platform
|
||||||
import shutil
|
import shutil
|
||||||
import sys
|
import sys
|
||||||
|
import copy
|
||||||
|
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
@ -3192,24 +3193,24 @@ class MainWindow(QMainWindow):
|
|||||||
# changes attributes of the corresponding event
|
# changes attributes of the corresponding event
|
||||||
table = self.project._table
|
table = self.project._table
|
||||||
event = self.project.getEventFromPath(table[row][1].text().split('*')[0])
|
event = self.project.getEventFromPath(table[row][1].text().split('*')[0])
|
||||||
if column == 9 or column == 10:
|
if column == 10 or column == 11:
|
||||||
# toggle checked states (exclusive)
|
# toggle checked states (exclusive)
|
||||||
item_ref = table[row][9]
|
item_ref = table[row][10]
|
||||||
item_test = table[row][10]
|
item_test = table[row][11]
|
||||||
if column == 9 and item_ref.checkState():
|
if column == 10 and item_ref.checkState():
|
||||||
item_test.setCheckState(QtCore.Qt.Unchecked)
|
item_test.setCheckState(QtCore.Qt.Unchecked)
|
||||||
event.setRefEvent(True)
|
event.setRefEvent(True)
|
||||||
elif column == 9 and not item_ref.checkState():
|
elif column == 10 and not item_ref.checkState():
|
||||||
event.setRefEvent(False)
|
event.setRefEvent(False)
|
||||||
elif column == 10 and item_test.checkState():
|
elif column == 11 and item_test.checkState():
|
||||||
item_ref.setCheckState(QtCore.Qt.Unchecked)
|
item_ref.setCheckState(QtCore.Qt.Unchecked)
|
||||||
event.setTestEvent(True)
|
event.setTestEvent(True)
|
||||||
elif column == 10 and not item_test.checkState():
|
elif column == 11 and not item_test.checkState():
|
||||||
event.setTestEvent(False)
|
event.setTestEvent(False)
|
||||||
self.fill_eventbox()
|
self.fill_eventbox()
|
||||||
elif column == 11:
|
elif column == 12:
|
||||||
# update event notes
|
# update event notes
|
||||||
notes = table[row][11].text()
|
notes = table[row][12].text()
|
||||||
event.addNotes(notes)
|
event.addNotes(notes)
|
||||||
self.fill_eventbox()
|
self.fill_eventbox()
|
||||||
|
|
||||||
@ -3230,7 +3231,7 @@ class MainWindow(QMainWindow):
|
|||||||
|
|
||||||
# init new qtable
|
# init new qtable
|
||||||
self.event_table = QTableWidget(self)
|
self.event_table = QTableWidget(self)
|
||||||
self.event_table.setColumnCount(12)
|
self.event_table.setColumnCount(len(self.table_headers))
|
||||||
self.event_table.setRowCount(len(eventlist))
|
self.event_table.setRowCount(len(eventlist))
|
||||||
self.event_table.setHorizontalHeaderLabels(self.table_headers)
|
self.event_table.setHorizontalHeaderLabels(self.table_headers)
|
||||||
|
|
||||||
@ -3318,7 +3319,7 @@ class MainWindow(QMainWindow):
|
|||||||
item_test.setCheckState(QtCore.Qt.Unchecked)
|
item_test.setCheckState(QtCore.Qt.Unchecked)
|
||||||
|
|
||||||
row = [item_delete, item_path, item_time, item_lat, item_lon, item_depth, item_localmag,
|
row = [item_delete, item_path, item_time, item_lat, item_lon, item_depth, item_localmag,
|
||||||
item_momentmag, item_nmp, item_nap, item_ref, item_test, item_notes]
|
item_momentmag, item_nmp, item_nap, item_ref, item_test, item_notes]
|
||||||
self.project._table.append(row)
|
self.project._table.append(row)
|
||||||
|
|
||||||
self.setItemColor(row, index, event, current_event)
|
self.setItemColor(row, index, event, current_event)
|
||||||
@ -3375,20 +3376,20 @@ class MainWindow(QMainWindow):
|
|||||||
|
|
||||||
def exportProjectTable(self, filename, separator=';'):
|
def exportProjectTable(self, filename, separator=';'):
|
||||||
with open(filename, 'w') as outfile:
|
with open(filename, 'w') as outfile:
|
||||||
for header in self.table_headers[1:12]:
|
for header in self.table_headers[1:13]:
|
||||||
outfile.write('{}{}'.format(header, separator))
|
outfile.write('{}{}'.format(header, separator))
|
||||||
outfile.write('\n')
|
outfile.write('\n')
|
||||||
|
|
||||||
for row in self.project._table:
|
for row in self.project._table:
|
||||||
row = row[1:12]
|
row = row[1:13]
|
||||||
event, time, lat, lon, depth, mag, nmp, nap, tune, test, notes = row
|
event, time, lat, lon, depth, ml, mw, nmp, nap, tune, test, notes = row
|
||||||
row_str = ''
|
row_str = ''
|
||||||
for index in range(len(row)):
|
for index in range(len(row)):
|
||||||
row_str += '{}'+'{}'.format(separator)
|
row_str += '{}'+'{}'.format(separator)
|
||||||
|
|
||||||
row_str = row_str.format(event.text(), time.text(), lat.text(), lon.text(), depth.text(), mag.text(),
|
row_str = row_str.format(event.text(), time.text(), lat.text(), lon.text(), depth.text(), ml.text(),
|
||||||
nmp.text(), nap.text(), bool(tune.checkState()), bool(test.checkState()),
|
mw.text(), nmp.text(), nap.text(), bool(tune.checkState()),
|
||||||
notes.text())
|
bool(test.checkState()), notes.text())
|
||||||
outfile.write(row_str + '\n')
|
outfile.write(row_str + '\n')
|
||||||
|
|
||||||
message = 'Wrote table to file: {}'.format(filename)
|
message = 'Wrote table to file: {}'.format(filename)
|
||||||
@ -3628,7 +3629,7 @@ class MainWindow(QMainWindow):
|
|||||||
autosaveXML = get_Bool(settings.value('autosaveXML', True))
|
autosaveXML = get_Bool(settings.value('autosaveXML', True))
|
||||||
if autosaveXML:
|
if autosaveXML:
|
||||||
self.exportEvents()
|
self.exportEvents()
|
||||||
self.project.save(filename)
|
if not self.project.save(filename): return False
|
||||||
self.setDirty(False)
|
self.setDirty(False)
|
||||||
self.saveProjectAsAction.setEnabled(True)
|
self.saveProjectAsAction.setEnabled(True)
|
||||||
self.update_status('Saved new project to {}'.format(filename), duration=5000)
|
self.update_status('Saved new project to {}'.format(filename), duration=5000)
|
||||||
@ -3652,7 +3653,7 @@ class MainWindow(QMainWindow):
|
|||||||
autosaveXML = get_Bool(settings.value('autosaveXML', True))
|
autosaveXML = get_Bool(settings.value('autosaveXML', True))
|
||||||
if autosaveXML:
|
if autosaveXML:
|
||||||
self.exportEvents()
|
self.exportEvents()
|
||||||
self.project.save()
|
if not self.project.save(): return False
|
||||||
self.update_obspy_dmt()
|
self.update_obspy_dmt()
|
||||||
if not self.project.dirty:
|
if not self.project.dirty:
|
||||||
self.setDirty(False)
|
self.setDirty(False)
|
||||||
@ -3879,34 +3880,37 @@ class Project(object):
|
|||||||
Can be loaded by using project.load(filename).
|
Can be loaded by using project.load(filename).
|
||||||
'''
|
'''
|
||||||
try:
|
try:
|
||||||
import cPickle
|
import pickle
|
||||||
except ImportError:
|
except ImportError:
|
||||||
import _pickle as cPickle
|
import _pickle as pickle
|
||||||
|
|
||||||
if filename:
|
if filename:
|
||||||
self.location = filename
|
self.location = filename
|
||||||
else:
|
else:
|
||||||
filename = self.location
|
filename = self.location
|
||||||
|
|
||||||
|
table = self._table # MP: see below
|
||||||
try:
|
try:
|
||||||
outfile = open(filename, 'wb')
|
outfile = open(filename, 'wb')
|
||||||
cPickle.dump(self, outfile, -1)
|
self._table = [] # MP: Workaround as long as table cannot be saved as part of project
|
||||||
|
pickle.dump(self, outfile, protocol=pickle.HIGHEST_PROTOCOL)
|
||||||
self.setDirty(False)
|
self.setDirty(False)
|
||||||
|
self._table = table # MP: see above
|
||||||
|
return True
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print('Could not pickle PyLoT project. Reason: {}'.format(e))
|
print('Could not pickle PyLoT project. Reason: {}'.format(e))
|
||||||
self.setDirty()
|
self.setDirty()
|
||||||
|
self._table = table # MP: see above
|
||||||
|
return False
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def load(filename):
|
def load(filename):
|
||||||
'''
|
'''
|
||||||
Load project from filename.
|
Load project from filename.
|
||||||
'''
|
'''
|
||||||
try:
|
import pickle
|
||||||
import cPickle
|
|
||||||
except ImportError:
|
|
||||||
import pickle as cPickle
|
|
||||||
infile = open(filename, 'rb')
|
infile = open(filename, 'rb')
|
||||||
project = cPickle.load(infile)
|
project = pickle.load(infile)
|
||||||
infile.close()
|
infile.close()
|
||||||
project.location = filename
|
project.location = filename
|
||||||
print('Loaded %s' % filename)
|
print('Loaded %s' % filename)
|
||||||
|
@ -296,13 +296,13 @@ class Event(ObsPyEvent):
|
|||||||
:rtype: None
|
:rtype: None
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
import cPickle
|
import pickle
|
||||||
except ImportError:
|
except ImportError:
|
||||||
import _pickle as cPickle
|
import _pickle as pickle
|
||||||
|
|
||||||
try:
|
try:
|
||||||
outfile = open(filename, 'wb')
|
outfile = open(filename, 'wb')
|
||||||
cPickle.dump(self, outfile, -1)
|
pickle.dump(self, outfile, -1)
|
||||||
self.dirty = False
|
self.dirty = False
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print('Could not pickle PyLoT event. Reason: {}'.format(e))
|
print('Could not pickle PyLoT event. Reason: {}'.format(e))
|
||||||
@ -317,11 +317,11 @@ class Event(ObsPyEvent):
|
|||||||
:rtype: Event
|
:rtype: Event
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
import cPickle
|
import pickle
|
||||||
except ImportError:
|
except ImportError:
|
||||||
import _pickle as cPickle
|
import _pickle as pickle
|
||||||
infile = open(filename, 'rb')
|
infile = open(filename, 'rb')
|
||||||
event = cPickle.load(infile)
|
event = pickle.load(infile)
|
||||||
event.dirty = False
|
event.dirty = False
|
||||||
print('Loaded %s' % filename)
|
print('Loaded %s' % filename)
|
||||||
return event
|
return event
|
||||||
|
Loading…
Reference in New Issue
Block a user