与Arduino交谈:在C#中工作,在Python中失败

2024-04-26 03:41:32 发布

您现在位置:Python中文网/ 问答频道 /正文

我需要和一个连接到USB端口的ArduinoPro微控制器通话。上载到其中的草图应响应带有调试响应的标准C#字符串:

> #NAME
>>> ARDUINO

(请求字符串没有换行终止符。)Arduino IDE中的串行端口监视器从连接的Arduino获得正确的响应。你知道吗

我自己编写了一个C#程序来测试通信,它也得到了正确的响应:

using System;
using System.IO.Ports;
using System.Threading;

class Program {
    static SerialPort port;

    // static void port_DataReceived(object sender, SerialDataReceivedEventArgs e) {
    //    // Show all the incoming data in the port's buffer
    //    Console.WriteLine(port.ReadExisting());
    //}

    static void Main(string[] args) {

        port = new SerialPort("COM5", 115200, Parity.None, 8, StopBits.One);

        //            port.DataReceived += port_DataReceived;

        Console.WriteLine("Port: " + port.PortName);

        port.Open();

        if (!port.IsOpen) {
            Console.WriteLine("Can't open port.");
            return;
        }

        Console.WriteLine("Writing '#NAME' to port...");
        port.Write("#NAME");

        Thread.Sleep(500);

        string ans = port.ReadExisting();
        Console.WriteLine("Response: " + ans + "| " + ans.Length);

        port.Close();
    }
}

输出:

Port: COM5
Writing '#NAME' to port...
Response: ARDUINO | 9

我尝试使用Python和pySerial模块与控制器对话:

import serial
from time import sleep

# msg = b'\x00\x23\x00\x4e\x00\x41\x00\x4d\x00\x45\n'
# msg = b'\x23\x4e\x41\x4d\x45\n'
# msg = b'#NAME\n'
# msg = b'\xff\xfe\x00\x00#\x00\x00\x00N\x00\x00\x00A\x00\x00\x00M\x00\x00\x00E\x00\x00\x00'
# msg = b'\xff\xfe#\x00N\x00A\x00M\x00E\x00'
# msg = bytes('#NAME', encoding="utf-8")
# msg = bytes('#NAME', encoding="utf-16")
# msg = bytearray([0x23, 0x4E, 0x41, 0x4D, 0x45])
# msg = bytearray(b"#NAME")
msg = "#NAME".encode("utf-16")

port = serial.Serial("COM5", baudrate=115200, parity=serial.PARITY_NONE, bytesize=8, stopbits=serial.STOPBITS_ONE, timeout=2)

print("Port:", port.name)
print("Is open?:", port.is_open)
print("Writing:", msg)

# port.writelines([msg])
port.write(msg)

sleep(1)

output = port.read_until(size=len(msg))
# output = port.read_all()
print("Reading:", output)

port.close()

但我无法让它做出正确的反应:

Port: COM5
Is open? True
Writing: b'\xff\xfe#\x00N\x00A\x00M\x00E\x00'
Reading: b''

pySerial的write方法不处理字符串,只接受字节序列,所以我尝试用不同的方法转换字符串。你知道吗

由于端口和控制器都正常工作,我认为Python或pySerial安装可能有问题,所以我尝试对它们进行测试。我有另一个控制器,它只是回显它得到的任何输入字节序列。使用相同的Python程序进行测试运行:

Port: COM5
Is open? True
Writing: b'\xff\xfe#\x00N\x00A\x00M\x00E\x00'
Reading: b'\xff\xfe#\x00N\x00A\x00M\x00E\x00'

有人能解释一下,发生了什么,我怎样才能和第一个使用Python的控制器交谈?你知道吗

更新:

我使用串行端口监视器程序监视数据流:

Arduino IDE串行监视器数据交换日志('#NAME',无结束行字节,波特率=115200):

Port opened by process "javaw.exe" (PID: 2792)

Request: 27.12.2017 16:24:37.38864
 23 4E 41 4D 45                                    #NAME           

Answer: 27.12.2017 16:24:37.58964 (+0.2010 seconds)
 41 52 44 55 49 4E 4F 0D 0A                        ARDUINO..       

Port closed

C#程序交换日志('#NAME',无结束行字节,波特率=115200):

Port opened by process "ConsoleApplication1.exe" (PID: 7004)

Request: 27.12.2017 16:31:24.69564 (+26.5445 seconds)
 23 4E 41 4D 45                                    #NAME           

Answer: 27.12.2017 16:31:26.72564 (+2.0291 seconds)
 41 52 44 55 49 4E 4F 0D 0A                        ARDUINO..       

Port closed

Python程序交换日志(b'#NAME',无结束行字节,波特率=115200):

Port opened by process "python.exe" (PID: 2416)

Request: 27.12.2017 16:39:32.00464 (+139.8020 seconds)
 23 4E 41 4D 45                                    #NAME           

Port closed

这三个程序都写相同的字节序列,我不明白,为什么Python程序没有得到响应。你知道吗


Tags: name程序字节portmsgopenconsolex00
3条回答

打印结果之前,请尝试msg = msg.decode('ascii')msg = msg.decode('utf-16')。在print("Writing:", msg)行之前。 我遇到了一个类似的问题,并尝试了这个,它为我工作。你知道吗

您正在对BOM使用UTF16编码,这很可能是不正确的。通常,这些协议要求ASCII带有换行符:

import serial
from time import sleep

msg = "#NAME\r\n".encode('ascii')
port = serial.Serial("COM5", baudrate=115200, parity=serial.PARITY_NONE, bytesize=8, stopbits=serial.STOPBITS_ONE, timeout=2)

print("Port:", port.name)
print("Is open?:", port.is_open)
print("Writing:", msg)

port.write(msg)
sleep(1)

output = port.read_until(size=len(msg))
print("Reading:", output)

port.close()

结果,我的控制器设备出了故障。我仍然不知道为什么它没有响应用Python发送的请求,而它同时使用C#和Arduino IDE进行响应,但是在用新设备替换它之后,我在所有环境中都得到了所需的响应。你知道吗

相关问题 更多 >