使用pexpect自动执行manage.py syncdb对话框

时间:2012-04-17 12:19:00

标签: python expect pexpect

我正在尝试使用pexpect来自动化这种对话。下面是使用pexpect的python程序。当我运行代码时......它等待输入“你想现在创建一个吗?(是/否):”然后超时并出现错误。它期待是或否。那么......我在哪里犯错?字符串匹配第一个输入?

ubuntu@ip-10-142-73-169:/opt/graphite/webapp/graphite$ sudo python manage.py syncdb
Creating tables ...
Creating table account_profile
Creating table account_variable
Creating table account_view
Creating table account_window
Creating table account_mygraph
Creating table dashboard_dashboard_owners
Creating table dashboard_dashboard
Creating table events_event
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table auth_user_user_permissions
Creating table auth_user_groups
Creating table auth_user
Creating table auth_message
Creating table django_session
Creating table django_admin_log
Creating table django_content_type
Creating table tagging_tag
Creating table tagging_taggeditem

You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): 
Username (Leave blank to use 'root'): 
E-mail address: 
Password: 
Password (again): 

Python脚本:

import pexpect
child = pexpect.spawn ('python /opt/graphite/webapp/graphite/manage.py syncdb')
child.expect ('Would you like to create one now? (yes/no):')
child.sendline ('yes')
child.expect ("""Username (Leave blank to use 'root'):""")
child.sendline ('admin')
child.expect ("E-mail address:")
child.sendline ('david@gmail.com')
child.expect ('Password:')
child.sendline ('test')
child.expect ('Password (again):')
child.sendline ('test')





Creating tables ...
Creating table account_profile
Creating table account_variable
Creating table account_view
Creating table account_window
Creating table account_mygraph
Creating table dashboard_dashboard_owners
Creating table dashboard_dashboard
Creating table events_event
Creating table auth_permission
Creating table auth_group_permissions
Creating table auth_group
Creating table auth_user_user_permissions
Creating table auth_user_groups
Creating table auth_user
Creating table auth_message
Creating table django_session
Creating table django_admin_log
Creating table django_content_type
Creating table tagging_tag
Creating table tagging_taggeditem

You just installed Django's auth system, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): Traceback (most recent call last):
  File "test.py", line 5, in <module>
    child.expect ('Would you like to create one now? (yes/no):')
  File "/usr/lib/python2.7/dist-packages/pexpect.py", line 1311, in expect
    return self.expect_list(compiled_pattern_list, timeout, searchwindowsize)
  File "/usr/lib/python2.7/dist-packages/pexpect.py", line 1325, in expect_list
    return self.expect_loop(searcher_re(pattern_list), timeout, searchwindowsize)
  File "/usr/lib/python2.7/dist-packages/pexpect.py", line 1409, in expect_loop
    raise TIMEOUT (str(e) + '\n' + str(self))
pexpect.TIMEOUT: Timeout exceeded in read_nonblocking().
<pexpect.spawn object at 0x7ffb875847d0>
version: 2.3 ($Revision: 399 $)
command: /usr/bin/python
args: ['/usr/bin/python', 'manage.py', 'syncdb']
searcher: searcher_re:
    0: re.compile("Would you like to create one now? (yes/no):")
buffer (last 100 chars): em, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): 
before (last 100 chars): em, which means you don't have any superusers defined.
Would you like to create one now? (yes/no): 
after: <class 'pexpect.TIMEOUT'>
match: None
match_index: None
exitstatus: None
flag_eof: False
pid: 12938
child_fd: 3
closed: False
timeout: 30
delimiter: <class 'pexpect.EOF'>
logfile: <open file '<stdout>', mode 'w' at 0x7ffb876c51e0>
logfile_read: None
logfile_send: None
maxread: 2000
ignorecase: False
searchwindowsize: None
delaybeforesend: 0.05
delayafterclose: 0.1
delayafterterminate: 0.1

2 个答案:

答案 0 :(得分:1)

我相信pexpect使用正则表达式语法。

child.expect ('Would you like to create one now.*?:')

我猜这上面的工作会很好 你也可以逃避'?'并且可能还有括号以获得更好的结果。

child.expect ('Would you like to create one now\? \(yes\/no\):')

答案 1 :(得分:1)

正则表达式语法也让我好一阵子。这是适用于我的自动化代码:

p = pexpect.spawn("python manage.py syncdb")
p.logfile = sys.stdout 
p.expect(r"Would you like to create one now\? \(yes\/no\): ")
p.sendline("yes")
p.expect(r"Username \(leave blank to use '.*'\): ")
p.sendline("admin")
p.expect(r"Email address: ")
p.sendline("admin@admin.com")
p.expect(r"Password: ")
p.sendline("admin")
p.expect(r"Password \(again\): ")
p.sendline("admin")