Commit 050af22188362a14e5caf7d40af5cb886898239f

Authored by bmarechal
1 parent 7db5c07792
Exists in master

datalogger-gui: replace E with e for float conversion

Showing 1 changed file with 1 additions and 0 deletions Inline Diff

#!/usr/bin/env python 1 1 #!/usr/bin/env python
2 2
# -*- coding: utf-8 -*- 3 3 # -*- coding: utf-8 -*-
4 4
import time, os, instruments, inspect, sys, threading 5 5 import time, os, instruments, inspect, sys, threading
import PyQt4.QtGui as QtGui 6 6 import PyQt4.QtGui as QtGui
from PyQt4.QtCore import pyqtSlot 7 7 from PyQt4.QtCore import pyqtSlot
8 8
#============================================================================== 9 9 #==============================================================================
#============================================================================== 10 10 #==============================================================================
11 11
class acq_routine(): 12 12 class acq_routine():
def __init__(self, instrument, channels, vtypes, address, path = os.getcwd(), samplingtime = 1, fileduration = 24*3600): 13 13 def __init__(self, instrument, channels, vtypes, address, path = os.getcwd(), samplingtime = 1, fileduration = 24*3600):
exec('self.instrument = instruments.%s.%s(%s, %s, "%s")'%(instrument, instrument, channels, vtypes, address)) 14 14 exec('self.instrument = instruments.%s.%s(%s, %s, "%s")'%(instrument, instrument, channels, vtypes, address))
self.path = path 15 15 self.path = path
self.samplingtime = samplingtime 16 16 self.samplingtime = samplingtime
self.fileduration = fileduration 17 17 self.fileduration = fileduration
18 18
def makeTree(self): 19 19 def makeTree(self):
try: 20 20 try:
year = time.strftime("%Y", time.gmtime(self.t0)) 21 21 year = time.strftime("%Y", time.gmtime(self.t0))
month = time.strftime("%Y-%m", time.gmtime(self.t0)) 22 22 month = time.strftime("%Y-%m", time.gmtime(self.t0))
os.chdir(self.path + '/' + year + '/' + month) 23 23 os.chdir(self.path + '/' + year + '/' + month)
except: 24 24 except:
try: 25 25 try:
os.chdir(self.path + '/' + year) 26 26 os.chdir(self.path + '/' + year)
os.mkdir(month) 27 27 os.mkdir(month)
os.chdir(self.path + '/' + year + '/' + month) 28 28 os.chdir(self.path + '/' + year + '/' + month)
except: 29 29 except:
os.chdir(self.path) 30 30 os.chdir(self.path)
os.mkdir(year) 31 31 os.mkdir(year)
os.chdir(self.path + '/' + year) 32 32 os.chdir(self.path + '/' + year)
os.mkdir(month) 33 33 os.mkdir(month)
os.chdir(self.path + '/' + year + '/' + month) 34 34 os.chdir(self.path + '/' + year + '/' + month)
35 35
def connect(self): 36 36 def connect(self):
self.instrument.connect() 37 37 self.instrument.connect()
38 38
self.t0 = time.time() 39 39 self.t0 = time.time()
self.filename = time.strftime("%Y%m%d-%H%M%S", time.gmtime(self.t0)) + '-' + self.instrument.model() + '.dat' 40 40 self.filename = time.strftime("%Y%m%d-%H%M%S", time.gmtime(self.t0)) + '-' + self.instrument.model() + '.dat'
self.makeTree() 41 41 self.makeTree()
self.data_file = open(self.filename, 'wr', 0) 42 42 self.data_file = open(self.filename, 'wr', 0)
43 43
def start(self): 44 44 def start(self):
tic = time.time() 45 45 tic = time.time()
46 46
if (time.time() - self.t0 >= self.fileduration) & (self.fileduration >0 ): 47 47 if (time.time() - self.t0 >= self.fileduration) & (self.fileduration >0 ):
self.data_file.close() 48 48 self.data_file.close()
49 49
self.t0 = time.time() 50 50 self.t0 = time.time()
self.filename = time.strftime("%Y%m%d-%H%M%S", time.gmtime(self.t0)) + '-' + self.instrument.model() + '.dat' 51 51 self.filename = time.strftime("%Y%m%d-%H%M%S", time.gmtime(self.t0)) + '-' + self.instrument.model() + '.dat'
self.makeTree() 52 52 self.makeTree()
self.data_file = open(self.filename, 'wr', 0) 53 53 self.data_file = open(self.filename, 'wr', 0)
54 54
#epoch time 55 55 #epoch time
epoch = time.time() 56 56 epoch = time.time()
#MJD time 57 57 #MJD time
mjd = epoch / 86400.0 + 40587 58 58 mjd = epoch / 86400.0 + 40587
# Meas values 59 59 # Meas values
meas = self.instrument.getValue() 60 60 meas = self.instrument.getValue()
meas = meas.replace(",", "\t") 61 61 meas = meas.replace(",", "\t")
meas = meas.replace(";", "\t") 62 62 meas = meas.replace(";", "\t")
meas = meas.replace("+", "") 63 63 meas = meas.replace("+", "")
64 meas = meas.replace("E", "e")
64 65
string = "%f\t%f\t%s" % (epoch, mjd, meas) 65 66 string = "%f\t%f\t%s" % (epoch, mjd, meas)
self.data_file.write(string) # Write in a file 66 67 self.data_file.write(string) # Write in a file
print(string) 67 68 print(string)
68 69
self.thread = threading.Timer(self.samplingtime - (time.time() - tic), self.start) 69 70 self.thread = threading.Timer(self.samplingtime - (time.time() - tic), self.start)
self.thread.start() 70 71 self.thread.start()
71 72
def stop(self): 72 73 def stop(self):
self.thread.cancel() 73 74 self.thread.cancel()
self.instrument.disconnect() 74 75 self.instrument.disconnect()
self.data_file.close() 75 76 self.data_file.close()
76 77
#============================================================================== 77 78 #==============================================================================
#============================================================================== 78 79 #==============================================================================
79 80
class mainGui(): 80 81 class mainGui():
def __init__(self): 81 82 def __init__(self):
self.setWindow() 82 83 self.setWindow()
self.setSignalsSlots() 83 84 self.setSignalsSlots()
self.runApp() 84 85 self.runApp()
85 86
def setWindow(self): 86 87 def setWindow(self):
self.a = QtGui.QApplication(sys.argv) 87 88 self.a = QtGui.QApplication(sys.argv)
self.w = QtGui.QMainWindow() 88 89 self.w = QtGui.QMainWindow()
self.w.resize(640, 480) 89 90 self.w.resize(640, 480)
self.w.setWindowTitle('datalogger-gui') 90 91 self.w.setWindowTitle('datalogger-gui')
91 92
self.wid = QtGui.QWidget() 92 93 self.wid = QtGui.QWidget()
self.w.setCentralWidget(self.wid) 93 94 self.w.setCentralWidget(self.wid)
self.layout = QtGui.QGridLayout() 94 95 self.layout = QtGui.QGridLayout()
self.wid.setLayout(self.layout) 95 96 self.wid.setLayout(self.layout)
96 97
self.comboInst = QtGui.QComboBox() 97 98 self.comboInst = QtGui.QComboBox()
self.layout.addWidget(self.comboInst, 0, 0) 98 99 self.layout.addWidget(self.comboInst, 0, 0)
99 100
self.address = QtGui.QLineEdit() 100 101 self.address = QtGui.QLineEdit()
self.address.setMinimumWidth(140) 101 102 self.address.setMinimumWidth(140)
self.address.setMaximumWidth(140) 102 103 self.address.setMaximumWidth(140)
self.layout.addWidget(self.address, 0, 1) 103 104 self.layout.addWidget(self.address, 0, 1)
104 105
self.startButton = QtGui.QPushButton() 105 106 self.startButton = QtGui.QPushButton()
self.startButton.setText('Start log') 106 107 self.startButton.setText('Start log')
self.layout.addWidget(self.startButton, 99, 0) 107 108 self.layout.addWidget(self.startButton, 99, 0)
self.startButton.setEnabled(False) 108 109 self.startButton.setEnabled(False)
109 110
self.stopButton = QtGui.QPushButton() 110 111 self.stopButton = QtGui.QPushButton()
self.stopButton.setText('Stop log') 111 112 self.stopButton.setText('Stop log')
self.layout.addWidget(self.stopButton, 99, 1) 112 113 self.layout.addWidget(self.stopButton, 99, 1)
self.stopButton.setEnabled(False) 113 114 self.stopButton.setEnabled(False)
114 115
self.textDisplay = QtGui.QLabel() 115 116 self.textDisplay = QtGui.QLabel()
self.textDisplay.setText('>>') 116 117 self.textDisplay.setText('>>')
self.layout.addWidget(self.textDisplay, 99, 2) 117 118 self.layout.addWidget(self.textDisplay, 99, 2)
118 119
self.setComboInst() 119 120 self.setComboInst()
self.updateSignal() 120 121 self.updateSignal()
121 122
def setComboInst(self): 122 123 def setComboInst(self):
for name, obj in inspect.getmembers(instruments): 123 124 for name, obj in inspect.getmembers(instruments):
if inspect.ismodule(obj) and name.startswith('__') == False and name.startswith('abstract') == False: 124 125 if inspect.ismodule(obj) and name.startswith('__') == False and name.startswith('abstract') == False:
self.comboInst.addItem(name) 125 126 self.comboInst.addItem(name)
126 127
def setSignalsSlots(self): 127 128 def setSignalsSlots(self):
self.comboInst.currentIndexChanged.connect(self.updateSignal) 128 129 self.comboInst.currentIndexChanged.connect(self.updateSignal)
self.startButton.clicked.connect(self.startLog) 129 130 self.startButton.clicked.connect(self.startLog)
self.stopButton.clicked.connect(self.stopLog) 130 131 self.stopButton.clicked.connect(self.stopLog)
131 132
def runApp(self): 132 133 def runApp(self):
self.w.show() 133 134 self.w.show()
self.a.aboutToQuit.connect(self.closeEvent) 134 135 self.a.aboutToQuit.connect(self.closeEvent)
sys.exit(self.a.exec_()) 135 136 sys.exit(self.a.exec_())
136 137
def closeEvent(self): 137 138 def closeEvent(self):
try: 138 139 try:
self.stopLog() 139 140 self.stopLog()
except: 140 141 except:
pass 141 142 pass
print('Done') 142 143 print('Done')
143 144
@pyqtSlot() 144 145 @pyqtSlot()
def updateSignal(self): 145 146 def updateSignal(self):
for i in reversed(range(5, self.layout.count())): 146 147 for i in reversed(range(5, self.layout.count())):
self.layout.itemAt(i).widget().setParent(None) 147 148 self.layout.itemAt(i).widget().setParent(None)
148 149
defaultAddress = '' 149 150 defaultAddress = ''
channelsAviables = [] 150 151 channelsAviables = []
vtypesAviables = [] 151 152 vtypesAviables = []
152 153
exec('channelsAviables = instruments.%s.ALL_CHANNELS'%self.comboInst.currentText()) 153 154 exec('channelsAviables = instruments.%s.ALL_CHANNELS'%self.comboInst.currentText())
exec('vtypesAviables = instruments.%s.ALL_VAL_TYPE'%self.comboInst.currentText()) 154 155 exec('vtypesAviables = instruments.%s.ALL_VAL_TYPE'%self.comboInst.currentText())
exec('defaultAddress = instruments.%s.ADDRESS'%self.comboInst.currentText()) 155 156 exec('defaultAddress = instruments.%s.ADDRESS'%self.comboInst.currentText())
156 157
self.address.setText(defaultAddress) 157 158 self.address.setText(defaultAddress)
158 159
self.checkBoxChannels = [None]*len(channelsAviables) 159 160 self.checkBoxChannels = [None]*len(channelsAviables)
self.chListVtypes = [None]*len(self.checkBoxChannels) 160 161 self.chListVtypes = [None]*len(self.checkBoxChannels)
161 162
for i in range(len(self.checkBoxChannels)): 162 163 for i in range(len(self.checkBoxChannels)):
self.checkBoxChannels[i] = QtGui.QCheckBox() 163 164 self.checkBoxChannels[i] = QtGui.QCheckBox()
self.checkBoxChannels[i].setText(channelsAviables[i]) 164 165 self.checkBoxChannels[i].setText(channelsAviables[i])
self.checkBoxChannels[i].setChecked(False) 165 166 self.checkBoxChannels[i].setChecked(False)
self.chListVtypes[i] = QtGui.QListWidget() 166 167 self.chListVtypes[i] = QtGui.QListWidget()
for vtype in vtypesAviables: 167 168 for vtype in vtypesAviables:
self.chListVtypes[i].addItem(vtype) 168 169 self.chListVtypes[i].addItem(vtype)
self.chListVtypes[i].setCurrentRow(0) 169 170 self.chListVtypes[i].setCurrentRow(0)
self.layout.addWidget(self.checkBoxChannels[i], i+3, 1) 170 171 self.layout.addWidget(self.checkBoxChannels[i], i+3, 1)
self.layout.addWidget(self.chListVtypes[i], i+3, 2) 171 172 self.layout.addWidget(self.chListVtypes[i], i+3, 2)
self.checkBoxChannels[i].stateChanged.connect(self.infoSignal) 172 173 self.checkBoxChannels[i].stateChanged.connect(self.infoSignal)
self.chListVtypes[i].currentItemChanged.connect(self.infoSignal) 173 174 self.chListVtypes[i].currentItemChanged.connect(self.infoSignal)
174 175
self.address.textChanged.connect(self.infoSignal) 175 176 self.address.textChanged.connect(self.infoSignal)
176 177
self.infoSignal() 177 178 self.infoSignal()
178 179
@pyqtSlot() 179 180 @pyqtSlot()
def infoSignal(self): 180 181 def infoSignal(self):
self.instToLog = self.comboInst.currentText() 181 182 self.instToLog = self.comboInst.currentText()
self.addressToLog = self.address.text() 182 183 self.addressToLog = self.address.text()
self.chToLog = [] 183 184 self.chToLog = []
self.vTypeToLog = [] 184 185 self.vTypeToLog = []
185 186
for i in range(len(self.checkBoxChannels)): 186 187 for i in range(len(self.checkBoxChannels)):
if self.checkBoxChannels[i].isChecked(): 187 188 if self.checkBoxChannels[i].isChecked():
self.chListVtypes[i].setEnabled(True) 188 189 self.chListVtypes[i].setEnabled(True)
self.chToLog.append(str(self.checkBoxChannels[i].text())) 189 190 self.chToLog.append(str(self.checkBoxChannels[i].text()))
self.vTypeToLog.append(str(self.chListVtypes[i].currentItem().text())) 190 191 self.vTypeToLog.append(str(self.chListVtypes[i].currentItem().text()))
else: 191 192 else:
self.chListVtypes[i].setEnabled(False) 192 193 self.chListVtypes[i].setEnabled(False)
193 194