我通过socket来实现TCP通讯发送数据。单是出现下面这种情况比如我要发送的是两个十六进制“27 88”,通过下面的程序发送。单是我接收到的却是“27 C2 88”我不知道是为什么会多出来这个“C2”。发送时程序采用。txt.encode()和txt .encode('UTF-8')结果都是一样的。这个问题不是接收端引起的。应该是客护端引起的。程序如下import socket # TCP通讯类port = 502ip = '192.168.0.101'BufSize = 1024tcpCliSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 创建 socket 对象tcpCliSock.connect((ip, port)) # 主动初始化TCP服务器连接txt="\x27\x88"tcpCliSock.sendall(txt.encode()) # 发送消息tcpCliSock.close() # .encode('UTF-8')请教一下各为大神。这是什么原因引起的。谢谢
txt="\x27\x88",这个是由两个转义字符构成的字符串。txt.encode()会使用utf-8编码方式将字符串编码为字节序列(bytes对象)。utf-8编码的话,txt.encode()会返回3字节的字节序列:b'\x27\xc2\x88',因为对于字符'\x88',用utf-8编码后是2个字节b'\xc2\x88'。所以,接收到的自然是3个字节的字节序列b'\x27\xc2\x88'。要解码后才是原字符串,即:b'\x27\xc2\x88'.decode()=='\x27\x88'的结果是True。