https://www.cnblogs.com/zhengweizhao/p/8426826.html
import serial导入模块然后就可以用了ser = serial.Serial(0) 是打开第一个串口print ser.portstr 能看到第一个串口的标识,windows下是COM1ser.write(“hello") 就是往串口里面写数据ser.close() 就是关闭ser表示的串口ser.open() 会打开这个串口ser = serial.Serial('COM1', 115200) 来设置波特率,当然还有专门的函数data = ser.read()可以读一个字符data = ser.read(20) 是读20个字符data = ser.readline() 是读一行,以/n结束,要是没有/n就一直读,阻塞。data = ser.readlines()和ser.xreadlines()都需要设置超时时间ser.baudrate = 9600 设置波特率ser 来查看当前串口的状态ser.isOpen() 看看这个串口是否已经被打开import serialser = serial.Serial('COM3')ser.setBaudrate(9600)ser.setByteSize(8)ser.setStopbits(1)print ser.portstrdata = ser.readline(0,'\r\n')data = ser.read(20)print data
我的串口操作:
# coding=utf-8import serialimport pymysqlimport threadingimport timex=serial.Serial('COM3',9600)#这是我的串口,测试连接成功,没毛病# i=0def fasong():#发送函数 while True: time.sleep(3) myinput= bytes([0X01,0X03,0X00,0X00,0X00,0X01,0X84,0X0A]) #这是我要发送的命令,原本命令是:01 03 00 00 00 01 84 0A x.write(myinput)def jieshou():#接收函数 while True: while x.inWaiting()>0: myout=x.read(7)#读取串口传过来的字节流,这里我根据文档只接收7个字节的数据 datas =''.join(map(lambda x:('/x' if len(hex(x))>=4 else '/x0')+hex(x)[2:],myout))#将数据转成十六进制的形式 new_datas = datas.split("/x")#将字符串分割,拼接下标4和5部分的数据 need = new_datas[4]+new_datas[5];#need是拼接出来的数据,比如:001a my_need = int(hex(int(need,16)),16)#将十六进制转化为十进制 sql = "INSERT INTO VOC_DATA(value,create_time)VALUES('"+str(my_need)+"',"+str(int(time.time()))+")" # 使用 execute() 方法执行 SQL 查询 # 执行sql语句 cursor.execute(sql) # 提交到数据库执行 db.commit()if __name__== '__main__': # 打开数据库连接 db = pymysql.connect("localhost","root","123456789","voc" ) # 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() t1 = threading.Thread(target=jieshou,name="jieshou")#线程1:不断的去请求数据 t2= threading.Thread(target=fasong, name="fasong")#线程2:不断地去接收数据 t2.start()#开启线程1 t1.start()#开启线程2