python中eof表示什么语句错误_python中pickle的EOF错误
根據這些評論,我對最有可能的問題有一個猜測,但至少有50%的可能性我猜錯了,在這種情況下……告訴我,我會刪除答案。在
我猜你是在嘗試使用流套接字,就好像它是一個消息序列一樣。這是網絡編程新手中非常常見的問題。在
想象一下發送者會這樣做:data = pickle.dumps(object);
self.sock.sendall(data)
接受者會這樣做:
^{pr2}$
在簡單的測試中,這可能在99%的時間內有效,但在實際應用中卻行不通。您將收到部分消息,或在一次呼叫中收到多條消息,或上述內容的一些有趣組合(如消息2的一半、消息3的全部和消息4的三分之一)。在
因此,您將向loads傳遞一條部分消息,并返回一個錯誤,告訴您它不是一個完整的pickle。在
這并不是因為任何東西都壞了,這才是所謂的工作原理。(TCP)套接字是一個流:一個字節序列,而不是一個消息序列。任何你想在上面建立的結構,你都必須在數據中構建。在
這意味著您必須設計和實現一個協議,以某種方式知道每個消息何時結束。最簡單的協議可能是行(顯然只有在消息不能有未經轉義的換行符時才有用)和netstrings,但是任何能讓您清楚地看到某些數據并說“這是消息0,這是消息1,等等”的任何東西都可以工作。在
通常,這意味著將接收到的數據附加到某個緩沖區中,并循環該緩沖區中的消息。例如,使用線條,而不是:while True:
line = sock.recv(4096)
do_stuff(line)
…你需要這個:rdbuf = ''
while True:
rdbuf += sock.recv(4096)
lines = rdbuf.split('\n')
rdbuf = lines[-1]
for line in lines[:-1]:
dostuff(line)
如果你仔細想想,這和文件沒什么不同。想象一下這個代碼:with open('foo.data', 'wb') as f:
f.write('123')
f.write('45')
with open('foo.data', 'rb') as f:
while True:
number = f.read()
這將讀到'12345',而不是{}。如果你想得到'123',你需要一些方法知道只讀取3個字節。插入一個長度前綴,或添加空格作為分隔符,或只是外部知道第一個數字總是3位數長…任何都可以,但您必須做一些的事情。在
總結
以上是生活随笔為你收集整理的python中eof表示什么语句错误_python中pickle的EOF错误的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言中函数调用中的传值与传址
- 下一篇: python队列精灵对战_python队