串口模塊的波特率比較特別,找了幾個串口工具都不支持。。。因此,乾脆用python本身來寫了,其實已經好奇很久了,別人的工具各類不順手。python
須要pyserial的支持,兼容各類平臺,不須要新編譯二進制文件。linux
先貼一個定時發送的代碼:windows
import serial import time ser = serial.Serial('/dev/ttyUSB0', 250000, timeout=1) print ser.isOpen() words="gggggggggggggggg" while (1): print "send 256x\""+words+"\" to remotes" startTime = time.time() times = 256 while (times): times -= 1 s = ser.write(words) endTime = time.time() print "use time: "+str(endTime-startTime) print "" time.sleep(5) ser.close()
而後是一些其它的方法:工具
1. 使用序號打開串口:ser = serial.Serial(0) 。but,怎麼肯定串口的序號???oop
2. 查看串口的名稱,啊哈,用1的方法打開串口後,你能夠產看串口的名字:print ser.portstr this
3. 先例化一個實體,再打開:spa
>>> ser = serial.Serial() >>> ser.baudrate = 19200 >>> ser.port = 0 >>> ser Serial<id=0xa81c10, open=False>(port='COM1', baudrate=19200, bytesize=8, parity='N', stopbits=1, timeout=None, xonxoff=0, rtscts=0) >>> ser.open() >>> ser.isOpen() True >>> ser.close() >>> ser.isOpen() False
好多人問 windows 下面提示設備不存在!親,windows 下面的串口設備名不同的啊,上面的代碼裏面 COM1 就是 windows 下面的設備。調試
4. 讀取數據的幾種方式code
>>> ser = serial.Serial('/dev/ttyS1', 19200, timeout=1) >>> x = ser.read() # read one byte >>> s = ser.read(10) # read up to ten bytes (timeout) >>> line = ser.readline() # read a '/n' terminated line >>> ser.close()
其中,若是隻是串口調試,直接ser.read(1000),這樣會把讀到的值直接打印到屏幕上。對象
5.全部參數
ser = serial.Serial( port=None, # number of device, numbering starts at # zero. if everything fails, the user # can specify a device string, note # that this isn't portable anymore # if no port is specified an unconfigured # an closed serial port object is created baudrate=9600, # baud rate bytesize=EIGHTBITS, # number of databits parity=PARITY_NONE, # enable parity checking stopbits=STOPBITS_ONE, # number of stopbits timeout=None, # set a timeout value, None for waiting forever xonxoff=0, # enable software flow control rtscts=0, # enable RTS/CTS flow control interCharTimeout=None # Inter-character timeout, None to disable )
6. exception:serial.SerialException
另外一個完整收發的例子,單片機數據以TLV(Type,Length,Value)格式發上來
#!/usr/bin/env python
# it's a program of luo, piedgogo@sina.com
import serial import array import os import signal from time import sleep flag_stop = False def onsignal_int(a,b): print "sigint!" global flag_stop flag_stop = True signal.signal(signal.SIGINT, onsignal_int)
signal.signal(signal.SIGTERM, onsignal_int) ser = serial.Serial('/dev/ttyUSB0', 9600, timeout = 0.001) print "serial.isOpen() =",ser.isOpen() cmd_send = "7b02000129cc00c80378290400640000cc7d0d0a" cmd_send = cmd_send.decode("hex") stop = "7b04047d0d0a" stop = stop.decode("hex") cmd_back = "" cmd_length = 0x00 cmd_count = 0x00 s = ser.write(cmd_send) while True: sleep(0.1) if flag_stop: # read data until Ctrl+c ser.write(stop) # send cmd stop before exit print "reset cmd has been sent!" sleep(0.05) break text = ser.read(1) # read one, with timout if text: # check if not timeout n = ser.inWaiting() # look if there is more to read if n: text = text + ser.read(n) #get it cmd_back = cmd_back + text text = "" if len(cmd_back) < 2: # go back if no enough data recvd continue if cmd_length == 0x00: # new loop cmd_length = ord(cmd_back[1]) # Type(1 byte),Length of Value(1 byte),Value print "new cmd length,",cmd_length if (cmd_length + 0x02) > len(cmd_back): # do nothing until all bytes is recvd continue # so far, we have got a full cmd
hex_list = [hex(ord(i)) for i in cmd_back] # more readable than data.encode("hex") print "In buffer:",hex_list
cmd_back = cmd_back[cmd_length+2:] # remove this cmd(TLV) from buffer cmd_length = 0 cmd_count += 1
print "==> %d cmds recvd."%(cmd_count) print "-------------" ser.close()
可用的串口列表,能夠用下面的方法獲取:
python -c "import serial.tools.list_ports;print [port for port in serial.tools.list_ports.comports() if port[2] != 'n/a']"
由於獲取的列表裏可能有「假冒」的,因此,上面的代碼還檢查了設備的 hwid。comports() 返回的是一個 list,元素是一個對象,查看其 type() 結果以下 :
type(port)
class 'serial.tools.list_ports_linux.SysFS'
查看文檔 pydoc serial.tools.list_ports_linux.SysFS,上面的 port[2] 是這個 port 的 hwid,另外還有 port[0] 是串口名稱,port[1]是 description 。