2
我有一個Scrapy蜘蛛運行幾天。我通常會嘗試檢查統計數據,比如它已經刮掉了多少物品等等。我只是在終端中運行下面的cmds,它給我統計。Python的telnetlib連接到Scrapy Telnet讀取統計信息
$ telnet [IP] [PORT]
>>> spider.name
alf-spider
>>> stats.get_stats()
...
現在我想用Python使用telnetlib做到這一點,但我無法實現上述結果。以下是我的Python代碼。
#!/usr/bin/env python
import sys
import getpass
import telnetlib
HOST = "192.168.1.5"
def main():
ports = ['6023']
if len(sys.argv) > 1:
ports = sys.argv[1].split(',')
for port in ports:
get_stats(port)
def get_stats(port):
tn = telnetlib.Telnet(HOST, port)
tn.write("spider.name\n")
print tn.read_all()
if __name__ == '__main__':
main()
上面的代碼如果運行只是掛起,直到強制關閉。我錯過了什麼?
您是否嘗試過調試此代碼?添加打印輸出,以便您可以瞭解此代碼掛起的位置? –
是的。 tn.read_all()永遠不會返回。 –
好的,也許這給了我們一個線索? 'Telnet.read_all() 讀取所有數據直到EOF;直到連接關閉。「 –