当发现python的串口无法打印全部的值,而且不确定是哪部分没打印的话可以使用e=ser.write(x)
这样来获取发送的字节数,其中x
为发送的数据,e
为获取到的字节数。通过比对发送的字节数来定位没发送到数据的位置。
比如我每次发送的是从txt文件读取的数据,字节数为1字节,那么我就可以像下面那样写:
with open(f"./SendFile/{pic.writeFileName}.txt", 'r') as file:
for dataInFile in file:
x = serhandle.SendHandle(data=dataInFile.strip(), pic=1)#strip为去除换行符
e = ser.write(x)
if e != 1:
print(f"n={n},data={x},dataInFile={dataInFile}")
n+=1
这样的话就可以获取到错误的位置、错误的值是什么以及原始的值是什么,以下为我这里运行的结果:
定位到位置是4317行后就可以从txt文件里看是什么原因了,以下为txt文件里的情况:
发现这里无法打印的原因是这里是根本就没值,被直接换行了,通过排查后发现是我直接用hex()
这个函数来将数转换成十六进制时没考虑转换后的数只有两位的情况,比如十进制数130
、十进制数98
,这两个值转换成十六进制分别是十六进制的82
、62
,而我想存储的值是0x1234----->0x12 0x34这样的情况。而如果转化的值是0x0082的话是没有前半部分的0x00的,只会是0x82。
而我的代码中对数的存储是这样写的:
temp = self.rgb_to_rgb565(dataTemp[0], dataTemp[1], dataTemp[2])
file.write(f"{temp[2:4]}\r"
f"{temp[4:]}\r")
所以这就是导致我这值没有并且直接换行的原因。
转换的代码改为下面的就可以了:
转换部分修改:
rgb565 = hex(rgb565)[2:].zfill(4)
return rgb565
存储部分修改:
temp = self.rgb_to_rgb565(dataTemp[0], dataTemp[1], dataTemp[2])
file.write(f"{temp[:2]}\r"
f"{temp[2:]}\r")
这样修改后,发送正常,存值也正常