some changes with tables
This commit is contained in:
parent
bdbaae9730
commit
04e589dd34
163
Main.py
163
Main.py
@ -1,5 +1,7 @@
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
import csv
|
||||||
|
import time
|
||||||
from PyQt6.QtCore import Qt
|
from PyQt6.QtCore import Qt
|
||||||
from PyQt6.QtGui import QAction
|
from PyQt6.QtGui import QAction
|
||||||
from PyQt6.QtWidgets import (QHBoxLayout,
|
from PyQt6.QtWidgets import (QHBoxLayout,
|
||||||
@ -27,7 +29,8 @@ from PyQt6.QtWidgets import (QHBoxLayout,
|
|||||||
QGridLayout,
|
QGridLayout,
|
||||||
QMenu,
|
QMenu,
|
||||||
QTableWidgetItem,
|
QTableWidgetItem,
|
||||||
|
QHeaderView,
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@ -128,7 +131,12 @@ class StartWindow(AbstractWindow):
|
|||||||
self.parent.change_number()
|
self.parent.change_number()
|
||||||
|
|
||||||
def enter_name(self):
|
def enter_name(self):
|
||||||
|
# make folder
|
||||||
self.parent.foldername = self.lineEdit.text()
|
self.parent.foldername = self.lineEdit.text()
|
||||||
|
self.parent.folder = os.path.join(os.getcwd(), self.parent.foldername)
|
||||||
|
if not os.path.exists(self.parent.folder):
|
||||||
|
os.mkdir(self.parent.folder)
|
||||||
|
|
||||||
self.flow.setEnabled(True)
|
self.flow.setEnabled(True)
|
||||||
self.main.setEnabled(True)
|
self.main.setEnabled(True)
|
||||||
self.lineEdit.setReadOnly(True)
|
self.lineEdit.setReadOnly(True)
|
||||||
@ -136,6 +144,7 @@ class StartWindow(AbstractWindow):
|
|||||||
|
|
||||||
class MainExperiment1Window(AbstractWindow):
|
class MainExperiment1Window(AbstractWindow):
|
||||||
def __init__(self, parent):
|
def __init__(self, parent):
|
||||||
|
# TODO : clean code
|
||||||
super().__init__()
|
super().__init__()
|
||||||
|
|
||||||
self.setWindowTitle('Основной эксперимент')
|
self.setWindowTitle('Основной эксперимент')
|
||||||
@ -143,44 +152,84 @@ class MainExperiment1Window(AbstractWindow):
|
|||||||
self.parent = parent
|
self.parent = parent
|
||||||
|
|
||||||
# make masthead
|
# make masthead
|
||||||
self.dataname = 'data.txt'
|
self.dataname = 'data.csv'
|
||||||
file = open(os(self.parent.foldername, self.dataname), 'w')
|
head_1 = 'I_0,mA'
|
||||||
file.write('I_0, mA U_34, mV t, s')
|
head_2 = 'U_34,mV'
|
||||||
file.close()
|
head_3 = 't,s'
|
||||||
|
with open(os.path.join(self.parent.folder, self.dataname), 'w') as file:
|
||||||
|
wr = csv.writer(file)
|
||||||
|
wr.writerow([head_1, head_2, head_3])
|
||||||
|
|
||||||
|
|
||||||
self.centralwidget = QWidget()
|
self.centralwidget = QWidget()
|
||||||
self.resize(1400, 800)
|
self.resize(1400, 800)
|
||||||
self.setCentralWidget(self.centralwidget)
|
self.setCentralWidget(self.centralwidget)
|
||||||
|
|
||||||
self.but = QPushButton('Измерение')
|
self.start = QPushButton('Старт')
|
||||||
# self.but.clicked.connect(self.but_click)
|
self.start.clicked.connect(self.start_clicked_nodata)
|
||||||
self.setCentralWidget(self.but)
|
self.start.setEnabled(False)
|
||||||
|
|
||||||
|
self.stop = QPushButton('Стоп')
|
||||||
|
self.stop.clicked.connect(self.stop_clicked)
|
||||||
|
self.stop.setEnabled(False)
|
||||||
|
|
||||||
grid_layout = QGridLayout(self) # Create QGridLayout
|
grid_layout = QGridLayout(self.centralwidget)
|
||||||
self.centralwidget.setLayout(grid_layout) # Set this layout in central widget
|
|
||||||
|
|
||||||
table = QTableWidget(self) # Create a table
|
self.table = QTableWidget(self) # Create a self.table
|
||||||
table.setColumnCount(3) #Set three columns
|
self.table.setColumnCount(3) #Set three columns
|
||||||
table.setRowCount(1) # and one row
|
self.table.setRowCount(0)
|
||||||
|
|
||||||
# Set the table headers
|
self.table.setHorizontalHeaderLabels([head_1, head_2, head_3])
|
||||||
table.setHorizontalHeaderLabels(["Header 1", "Header 2", "Header 3"])
|
|
||||||
|
header = self.table.horizontalHeader()
|
||||||
|
header.setSectionResizeMode(0, QHeaderView.ResizeMode.Stretch)
|
||||||
|
header.setSectionResizeMode(1, QHeaderView.ResizeMode.Stretch)
|
||||||
|
header.setSectionResizeMode(2, QHeaderView.ResizeMode.Stretch)
|
||||||
|
self.table.setItem(0, 0, QTableWidgetItem("Text in column 1"))
|
||||||
|
self.table.setItem(0, 1, QTableWidgetItem("Text in column 2"))
|
||||||
|
self.table.setItem(0, 2, QTableWidgetItem("Text in column 3"))
|
||||||
|
self.table.resizeColumnsToContents()
|
||||||
|
|
||||||
|
|
||||||
|
self.lineEdit = QLineEdit(placeholderText='Введите что-то')
|
||||||
|
self.lineEdit.returnPressed.connect(self.enter_smth)
|
||||||
|
|
||||||
#Set the tooltips to headings
|
grid_layout.addWidget(self.table, 0, 0, 2, 1) # Adding the table to the grid
|
||||||
table.horizontalHeaderItem(0).setToolTip("Column 1 ")
|
grid_layout.addWidget(self.lineEdit, 0, 2, -1, -1)
|
||||||
table.horizontalHeaderItem(1).setToolTip("Column 2 ")
|
grid_layout.addWidget(self.start, 1, 2)
|
||||||
table.horizontalHeaderItem(2).setToolTip("Column 3 ")
|
grid_layout.addWidget(self.stop, 1, 3)
|
||||||
table.setItem(0, 0, QTableWidgetItem("Text in column 1"))
|
|
||||||
table.setItem(0, 1, QTableWidgetItem("Text in column 2"))
|
|
||||||
table.setItem(0, 2, QTableWidgetItem("Text in column 3"))
|
|
||||||
|
|
||||||
# Do the resize of the columns by content
|
|
||||||
table.resizeColumnsToContents()
|
self.parent.draw()
|
||||||
|
|
||||||
|
def enter_smth(self):
|
||||||
|
# TODO
|
||||||
|
self.parent.smth = self.lineEdit.text()
|
||||||
|
self.start.setEnabled(True)
|
||||||
|
self.lineEdit.setReadOnly(True)
|
||||||
|
|
||||||
|
def start_clicked_nodata(self):
|
||||||
|
# function to test writing data
|
||||||
|
current_time = round(time.time()*1000)
|
||||||
|
v = str(current_time/60)
|
||||||
|
a=v
|
||||||
|
t = str(current_time-self.start_time)
|
||||||
|
with open(os.path.join(self.parent.folder, self.dataname), 'a') as file:
|
||||||
|
wr = csv.writer(file)
|
||||||
|
wr.writerow([v, a, str(current_time-self.start_time)])
|
||||||
|
self.table.insertRow(self.table.rowCount())
|
||||||
|
self.table.setItem(self.table.rowCount()-1, 0, QTableWidgetItem(v))
|
||||||
|
self.table.setItem(self.table.rowCount()-1, 1, QTableWidgetItem(a))
|
||||||
|
self.table.setItem(self.table.rowCount()-1, 2, QTableWidgetItem(t))
|
||||||
|
|
||||||
|
self.stop.setEnabled(True)
|
||||||
|
|
||||||
|
def stop_clicked(self):
|
||||||
|
# TODO
|
||||||
|
print('stop')
|
||||||
|
self.stop.setEnabled(False)
|
||||||
|
|
||||||
grid_layout.addWidget(table, 0, 0) # Adding the table to the grid
|
def start_click(self):
|
||||||
grid_layout.addWidget(self.but, 0, 3)
|
|
||||||
|
|
||||||
def but_click(self):
|
|
||||||
# measure voltage and current
|
# measure voltage and current
|
||||||
volt_name = os.path.join('/dev', 'usbtmc1')
|
volt_name = os.path.join('/dev', 'usbtmc1')
|
||||||
f_volt = open(volt_name, 'w')
|
f_volt = open(volt_name, 'w')
|
||||||
@ -199,34 +248,34 @@ class MainExperiment1Window(AbstractWindow):
|
|||||||
f_amp.close()
|
f_amp.close()
|
||||||
current_time = round(time.time()*1000)
|
current_time = round(time.time()*1000)
|
||||||
s = v + a + str(current_time - self.start_time)
|
s = v + a + str(current_time - self.start_time)
|
||||||
out = open(os(self.parent.foldername, self.dataname), 'a')
|
with open(os.path.join(self.parent.folder, self.dataname), 'a') as file:
|
||||||
out.write(s)
|
wr = csv.writer(file)
|
||||||
out.close()
|
wr.writerow([v, a, str(current_time-self.start_time)])
|
||||||
|
|
||||||
|
start = Start()
|
||||||
|
|
||||||
# start = Start()
|
# =============================================================================
|
||||||
# del start
|
# import time
|
||||||
|
# import serial
|
||||||
|
#
|
||||||
import time
|
# ser=serial.Serial(
|
||||||
import serial
|
# port='/dev/ttyUSB0',
|
||||||
|
# baudrate=9600,
|
||||||
ser=serial.Serial(
|
# timeout=1
|
||||||
port='/dev/ttyUSB0',
|
# )
|
||||||
baudrate=9600,
|
# ser.isOpen()
|
||||||
timeout=1
|
#
|
||||||
)
|
# msg='SYSTem:REMote\n'
|
||||||
ser.isOpen()
|
# ser.write(msg.encode('ascii'))
|
||||||
|
#
|
||||||
msg='SYSTem:REMote\n'
|
# while 1:
|
||||||
ser.write(msg.encode('ascii'))
|
#
|
||||||
|
# msg='Read?\n'
|
||||||
while 1:
|
# ser.write(msg.encode('ascii'))
|
||||||
|
# time.sleep(1)
|
||||||
msg='Read?\n'
|
#
|
||||||
ser.write(msg.encode('ascii'))
|
# bytesToRead=ser.inWaiting()
|
||||||
time.sleep(1)
|
# data=ser.read(bytesToRead)
|
||||||
|
# print(data)
|
||||||
bytesToRead=ser.inWaiting()
|
#
|
||||||
data=ser.read(bytesToRead)
|
# =============================================================================
|
||||||
print(data)
|
|
||||||
|
Loading…
Reference in New Issue
Block a user