Python TCP通讯发送Byte出现数据里面多出一上字符是怎么回事?

我通过socket来实现TCP通讯发送数据。单是出现下面这种情况
比如我要发送的是两个十六进制“27 88”,通过下面的程序发送。单是我接收到的却是“27 C2 88”我不知道是为什么会多出来这个“C2”。发送时程序采用。txt.encode()和txt .encode('UTF-8')结果都是一样的。这个问题不是接收端引起的。应该是客护端引起的。
程序如下
import socket # TCP通讯类
port = 502
ip = '192.168.0.101'
BufSize = 1024
tcpCliSock = 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')

请教一下各为大神。这是什么原因引起的。谢谢
最新回答
寂月灭影

2024-09-02 17:52:31

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。