首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PEXPECT超时

PEXPECT超时
EN

Stack Overflow用户
提问于 2015-11-03 16:03:54
回答 1查看 1.6K关注 0票数 1

我只是尝试设置一个脚本来从基于unix的设备中检索一些输出,在这里您可以找到我的代码:

代码语言:javascript
复制
import pexpect
import time,sys, traceback, os



telconn = pexpect.spawn('telnet 192.168.1.1')
telconn.logfile = sys.stdout

telconn.expect("Enter Choice>")
telconn.send("tacl" + "\r")

telconn.expect("TACL 1>")
telconn.send("logon node.mgr" + "\r")


telconn.expect("Password:")
telconn.send("psw" + "\r")

telconn.expect('$SYSTEM NODEMGR 1>')
telconn.send("osh" + "\r") 

实际上,它可以正常工作,直到检索横幅(如果可能是问题)和右边的cli提示符,您可以在这里查看输出:

代码语言:javascript
复制
python try.py 
Trying 192.168.1.1...
Connected to 192.168.1.1.
Escape character is '^]'.




Available Services:

TACL     EXIT     
taclr Choice> tacl
logon node.mgrnode.mgr
Password: psw
Last Logon:  03 NOV 2015, 15:18
Last Unsuccessful Attempt: 03 NOV 2015, 15:17  Total Failures: 24
********************************************************************************November 3, 2015 15:51:57
********************************************************************************
              This is a private system operated for XXX XXXXX

            Authorization from XXX XXXXX management is required
                           for access to this system

                   Use by unauthorized persons is prohibited


********************************************************************************
********************************************************************************(Invoking $SYSTEM.NODEMGR.TACLCSTM)

Loaded from $SYSTEM.CBCLOCL.TACLMACS:

FI FN V SV P F H DS CD LS CAT QUEUE FS PE SPE SP T SCPA SCPB SCPC SCPD

Current volume is $SYSTEM.NODEMGR


 $SYSTEM NODEMGR 1> Traceback (most recent call last):

  File "try.py", line 22, in <module>
    telconn.expect('$SYSTEM NODEMGR 1>')
  File "/usr/lib/python2.7/dist-packages/pexpect/__init__.py", line 1418, in expect
    timeout, searchwindowsize)
  File "/usr/lib/python2.7/dist-packages/pexpect/__init__.py", line 1433, in expect_list
    timeout, searchwindowsize)
  File "/usr/lib/python2.7/dist-packages/pexpect/__init__.py", line 1535, in expect_loop
    raise TIMEOUT(str(err) + '\n' + str(self))
pexpect.TIMEOUT: Timeout exceeded.
<pexpect.spawn object at 0xb7259acc>
version: 3.1
command: /usr/bin/telnet
args: ['/usr/bin/telnet', '192.168.1.1']
searcher: <pexpect.searcher_re object at 0xb726f7ac>
buffer (last 100 chars): 'T QUEUE FS PE SPE SP T SCPA SCPB SCPC SCPD\r\n\r\nCurrent volume is $SYSTEM.NODEMGR\r\n$SYSTEM NODEMGR 1> '
before (last 100 chars): 'T QUEUE FS PE SPE SP T SCPA SCPB SCPC SCPD\r\n\r\nCurrent volume is $SYSTEM.NODEMGR\r\n$SYSTEM NODEMGR 1> '
after: <class 'pexpect.TIMEOUT'>
match: None
match_index: None
exitstatus: None
flag_eof: False
pid: 10135
child_fd: 3
closed: False
timeout: 30
delimiter: <class 'pexpect.EOF'>
logfile: <open file '<stdout>', mode 'w' at 0xb753e078>
logfile_read: None
logfile_send: None
maxread: 2000
ignorecase: False
searchwindowsize: None
delaybeforesend: 0.05
delayafterclose: 0.1
delayafterterminate: 0.1

如您所见,我最后的提示符是:

代码语言:javascript
复制
$SYSTEM NODEMGR 1> 

之后,我得到了:Traceback (most recent call last):

有人能帮我解决这个问题吗?我只想继续检索一些输出,但我在这一点上被困了!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-03 19:04:54

$ char在telconn.expect('$SYSTEM NODEMGR 1>')中被解释为正则元字符,根据医生的说法

匹配在行的末尾,行定义为字符串的结尾,或任何位置,后面跟着换行符。

这将导致脚本无法匹配包含文字$字符的输入,从而导致超时。

你有几个选择:

  • 转义元字符regex元字符,小心谨慎
  • 使用.expect_exact()代替.expect(),后者使用普通字符串匹配而不是编译的正则表达式。
  • 减少模式匹配,方法是完全删除$ (即使用telconn.expect('SYSTEM NODEMGR 1>')),如果剩余的字符串仍然足够重要,以便进行适当的脚本操作
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33503706

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档