forked from netmaniac/serial_logger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.py
executable file
·53 lines (49 loc) · 1.55 KB
/
logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
from __future__ import print_function
from time import gmtime, sleep
from datetime import datetime
import serial
import os
from serial.tools import list_ports
import argparse
def list_serial_ports():
# Windows
if os.name == 'nt':
# Scan for available ports.
available = []
for i in range(256):
try:
s = serial.Serial(i)
available.append('COM'+str(i + 1))
s.close()
except serial.SerialException:
pass
return available
else:
# Mac / Linux
return [port[0] for port in list_ports.comports()]
def print_serial_ports():
ret = list_serial_ports()
print('\n'.join(ret))
parser = argparse.ArgumentParser()
parser.add_argument("-l", "--list", help='List serial ports and stop', action='store_true')
parser.add_argument("-p", "--port", help='Serial port used to listen to (defaults to ttyACM0)', default='/dev/ttyACM0')
parser.add_argument("-b", "--baudrate", help='Specify baudrate (defaults to 9600)', default=9600)
args = parser.parse_args()
if args.list:
print_serial_ports();
exit(0);
port=args.port
speed = args.baudrate
ser = serial.Serial(port, speed, timeout=1)
if ser.isOpen():
print("Otwarty")
else:
print("Port nie otwarty")
exit(1)
sleep(1)
ser.flushInput()
while True:
line = ser.readline()
if line != '':
print(datetime.now().strftime("'%d %b %Y %H:%M:%S.%f',")+line.decode('ascii', errors='ignore'), end='')
# strftime("'%d %b %Y %H:%M:%S.%f',", gmtime())+line, end='')