2013-08-31 59 views
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() 

上面的代碼如果運行只是掛起,直到強制關閉。我錯過了什麼?

+0

您是否嘗試過調試此代碼?添加打印輸出,以便您可以瞭解此代碼掛起的位置? –

+0

是的。 tn.read_all()永遠不會返回。 –

+0

好的,也許這給了我們一個線索? 'Telnet.read_all() 讀取所有數據直到EOF;直到連接關閉。「 –

回答

0

這將工作。

#!/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.read_until('>>>') 
    tn.write("spider.name\n") 
    print tn.read_until('>>>') 
    tn.close() 

if __name__ == '__main__': 
    main()