Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

I am writing an application for a digital lab balance that connects over serial. To build the application I set up a COM port bridge and wrote a program to simulate the balance on my machine (the balance was in use). I will show you the most recent version of the balance simulation program:

import serial, random, time

s = serial.Serial('COM2')

#Initially we will just push a random float
#After the data the scale sends a carraige return + line feed

def pushData():
    data = f'{round(random.uniform(10, 100), 2)}
'.encode()
    print(f'Sending Data: {data}')
    s.write(data)

try:
    while True:
        pushData()
        time.sleep(10)
except:
    print('Something went wrong.')

This code along with my balance application works as expected on my machine. But when I try to use my balance program with the actual device it does not get all the serial data if it even works at all. I am wondering if I need some kind of multi-threading, if its a timing issue or something. I know the balance works because I can monitor the COM port.

I will post my most recent balance program here:

# !/usr/bin/python3

################ Imports
import serial, pyperclip
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg
from datetime import datetime, time
from tkinter import *

################ Declarations
GUI = Tk()

s = serial.Serial('COM5', timeout=1)

wgtList = [0,0,0,0,0]

wgtDict = {'Lab':[],
           'Weight':[]}

newL = '
'

tareWgt = 0

newWgt = 0 #Trying to get past program not working when no data is pushed

################ Functions

def thisAfter():
    """Updates scale feed and updates the scale feed."""
    try:
        global newWgt
        newWgt = float(s.readline().decode().rstrip('
')) - tareWgt
    except ValueError:
        #print('ValueError thisAfter(): NO DATA OR COULD NOT CONVERT SERIAL DATA TO FLOAT')
        print('ValueError thisAfter(): '+ str(newWgt))
        print('wgtList: '+ str(wgtList))
    wgtList.append(newWgt)
    if newWgt not in wgtList[0:5]:
        text.insert(INSERT,str(newWgt)+newL)
    if len(wgtList) > 5:
        del wgtList[0]
    GUI.after(50, thisAfter)
    text.see(END)

def labCallback():
    """Saves data to file, iterates the entry field."""
    num = labEntry.get()
    csvStr = datetime.today().strftime("%Y/%m/%d") + ',' + datetime.now().strftime("%H:%M:%S") + ',' + num + ',' + str(wgtList[-1]) + ',' + var1.get() + ',' + str(tareWgt) + newL
    with open('data.csv', 'a+', newline = '') as file:
        if file.readline() == None:
            file.write('Date, Time, Lab, Weight, Type' + newL)
        file.write(csvStr)
    #print(csvStr) #Just checking
    labEntry.delete(0,END) 
    labEntry.insert(0, int(num) + 1)
    csvArr = csvStr.split(',')
    wgtDict['Lab'].append(int(csvArr[2]))
    wgtDict['Weight'].append(float(csvArr[3]))
    text2.insert(INSERT, ','.join(csvArr))
    text2.see(END)
    #print(str(wgtDict)+'
')

def tareCallback(): 
    global tareWgt
    tareWgt = wgtList[-1]
    print(tareWgt)
    text3.insert(INSERT,newL+str(tareWgt))
    text3.see(END)

def copyData():
    global newWgt
    pyperclip.copy(newWgt)

def close():
    s.close()

def start():
    global s
    try:
        s = serial.Serial('COM5', timeout=1)
        thisAfter()
    except:
        print('Serial port closed')
    
    
################ Frames/Panes
frame1 = LabelFrame(GUI, text = 'Lab Label + Entry Field')
frame1.pack(side = TOP)

frame6 = LabelFrame(frame1, text = 'Tare')
frame6.pack(side = BOTTOM)

frame2 = LabelFrame(GUI, text = 'Scale Feed')
frame2.pack(side = BOTTOM)

frame3 = LabelFrame(GUI, text = 'Saved Feed')
frame3.pack(side = BOTTOM)

frame4 = LabelFrame(GUI, text = 'Plot')
frame4.pack(side = TOP)

frame5 = LabelFrame(frame1, text = 'Type Select')
frame5.pack(side = BOTTOM)

################ Lab Label + Entry Field + Type Select
labLabel = Label(frame1, bd = 5, text = 'Lab#')
labLabel.pack(side = LEFT)
tareLabel = Label(frame6, bd = 5, text = 'Tare')
tareLabel.pack(side = LEFT)
text3 = Text(frame6, height = 1, width = 20)
text3.pack(side = RIGHT)
closeButton = Button(frame1, text = 'Close', command = close)
closeButton.pack(side = RIGHT)
startButton = Button(frame1, text = 'Start', command = start)
startButton.pack(side = RIGHT)
tareButton = Button(frame1, text = 'Tare', command = tareCallback)
tareButton.pack(side = RIGHT)
undoButton = Button(frame1, text = 'Undo')
undoButton.pack(side = RIGHT)
labButton = Button(frame1, text = 'Save', command = labCallback)
labButton.pack(side = RIGHT)
copyButton = Button(frame1, text = 'Copy', command = copyData)
copyButton.pack(side = RIGHT)
labEntry = Entry(frame1)
labEntry.pack(side = RIGHT)


var1 = StringVar()

r1 = Radiobutton(frame5, text = 'pH', variable= var1, value = 'pH')
r1.pack(anchor = 's')
r2 = Radiobutton(frame5, text = 'pH-Tray', variable= var1, value = 'pH-Tray')
r2.pack(anchor = 's')
r3 = Radiobutton(frame5, text = 'Mehlich', variable= var1, value = 'Mehlich')
r3.pack(anchor = 's')
r4 = Radiobutton(frame5, text = 'Nitrate', variable= var1, value = 'Nitrate')
r4.pack(anchor = 's')
r5 = Radiobutton(frame5, text = 'Excel', variable= var1, value = 'Excel')
r5.pack(anchor = 's')
r6 = Radiobutton(frame5, text = 'Excel-Tray', variable= var1, value = 'Excel-Tray', state=DISABLED)
r6.pack(anchor = 's')

r1.select()
r2.deselect()
r3.deselect()
r4.deselect()
r5.deselect()
r6.deselect()



################ Scale Feed
scrollbar = Scrollbar(frame2)
scrollbar.pack(side = RIGHT, fill = Y)
text = Text(frame2, yscrollcommand = scrollbar.set, height = 10)
text.pack()
text.bind('<ButtonPress>', lambda e: 'break')
scrollbar.config(command = text.yview)
#thisAfter()

################ Saved Feed
scrollbar = Scrollbar(frame3)
scrollbar.pack(side = RIGHT, fill = Y)
text2 = Text(frame3, yscrollcommand = scrollbar.set, height = 10)
text2.pack()
scrollbar.config(command = text.yview)

################ Plot

f = plt.Figure(dpi=50, figsize=(13, 4))
plt.xkcd()
a = f.add_subplot(111)

def animate(i):
    xL = wgtDict['Lab']
    yL = wgtDict['Weight']
    a.clear()
    a.plot(xL, yL)
        
    
canvas = FigureCanvasTkAgg(f, frame4)
canvas.get_tk_widget().pack(side = LEFT, fill = BOTH)

ani = animation.FuncAnimation(f, animate, interval=1000)

# This is some kind of 'while true' loop fyi
GUI.mainloop()

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
302 views
Welcome To Ask or Share your Answers For Others

1 Answer

等待大神答复

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...