我正在尝试使用 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