python中eof表示什么语句错误_python中pickle的EOF错误
根據(jù)這些評論,我對最有可能的問題有一個猜測,但至少有50%的可能性我猜錯了,在這種情況下……告訴我,我會刪除答案。在
我猜你是在嘗試使用流套接字,就好像它是一個消息序列一樣。這是網(wǎng)絡編程新手中非常常見的問題。在
想象一下發(fā)送者會這樣做:data = pickle.dumps(object);
self.sock.sendall(data)
接受者會這樣做:
^{pr2}$
在簡單的測試中,這可能在99%的時間內(nèi)有效,但在實際應用中卻行不通。您將收到部分消息,或在一次呼叫中收到多條消息,或上述內(nèi)容的一些有趣組合(如消息2的一半、消息3的全部和消息4的三分之一)。在
因此,您將向loads傳遞一條部分消息,并返回一個錯誤,告訴您它不是一個完整的pickle。在
這并不是因為任何東西都壞了,這才是所謂的工作原理。(TCP)套接字是一個流:一個字節(jié)序列,而不是一個消息序列。任何你想在上面建立的結(jié)構(gòu),你都必須在數(shù)據(jù)中構(gòu)建。在
這意味著您必須設計和實現(xiàn)一個協(xié)議,以某種方式知道每個消息何時結(jié)束。最簡單的協(xié)議可能是行(顯然只有在消息不能有未經(jīng)轉(zhuǎn)義的換行符時才有用)和netstrings,但是任何能讓您清楚地看到某些數(shù)據(jù)并說“這是消息0,這是消息1,等等”的任何東西都可以工作。在
通常,這意味著將接收到的數(shù)據(jù)附加到某個緩沖區(qū)中,并循環(huán)該緩沖區(qū)中的消息。例如,使用線條,而不是: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個字節(jié)。插入一個長度前綴,或添加空格作為分隔符,或只是外部知道第一個數(shù)字總是3位數(shù)長…任何都可以,但您必須做一些的事情。在
總結(jié)
以上是生活随笔為你收集整理的python中eof表示什么语句错误_python中pickle的EOF错误的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言中函数调用中的传值与传址
- 下一篇: websocket python爬虫_p