使用Pexpect的自动化一个manage.py执行syncdb对话(Using pexpect t

2019-10-16 14:44发布

我试图使用Pexpect的自动完成这一对话。 另外以下为使用Pexpect的Python程序。 当我运行的代码......它等待输入在“您想现在创建一个(是/否)?”然后timesout一个错误。 它期待一个yes或no。 所以......在哪里我错了? 该字符串的第一个输入相匹配?

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

Answer 1:

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

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

我猜上面会正常工作。
你可以或者逃脱“?” 也可能是括号得到更好的结果也。

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


Answer 2:

正则表达式的语法被绊倒了我一会儿为好。 下面是对我工作的自动化代码:

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")


文章来源: Using pexpect to automate a manage.py syncdb dialogue