写一个python脚本,可以支持传入两个参数,参数1:指定log文件,参数2:指定uart设备端,参数3:指定uart波特率。脚本中写一个函数,将uart的输出打印到log文件
时间: 2024-09-07 07:01:53 浏览: 83
在Python中,你可以创建一个简单的命令行脚本来满足这个需求。首先,你需要导入所需的库,如`logging`处理日志和`serial`操作串口。下面是一个基本的示例:
```python
import sys
import logging
import serial
def setup_uart_logger(log_file, uart_device, baud_rate):
# 设置日志记录级别和文件处理器
log_formatter = logging.Formatter('%(asctime)s - %(message)s')
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)
# 创建一个FileHandler,用于写入日志文件
file_handler = logging.FileHandler(log_file, mode='w')
file_handler.setFormatter(log_formatter)
logger.addHandler(file_handler)
# 初始化串口连接
try:
ser = serial.Serial(uart_device, baud_rate, timeout=1)
logger.info(f"Connected to UART device at {uart_device} with a baud rate of {baud_rate}")
except serial.SerialException as e:
logger.error(f"Failed to connect to UART: {e}")
return
def print_uart_output(data):
# 这里只是一个简化示例,实际应用需要根据数据格式解析
logger.info(f"Received from UART: {data.strip()}")
ser.timeout = None # 设置无超时,实时接收
ser.on_data_received = print_uart_output # 当接收到新数据时触发回调
if __name__ == "__main__":
if len(sys.argv) != 4:
print("Usage: python script.py <log_file> <uart_device> <baud_rate>")
else:
log_file, uart_device, baud_rate = sys.argv[1:]
setup_uart_logger(log_file, uart_device, int(baud_rate))
```
为了运行此脚本,你需要在命令行输入类似这样的命令:
```sh
python script.py my_log_file.log /dev/ttyUSB0 9600
```
其中`my_log_file.log`是你的日志文件名,`/dev/ttyUSB0`是你的UART设备路径,`9600`是波特率。
阅读全文