#!/usr/bin/env python import pexpect import getpass, os srvs = [ "server01", "server02", ]; def ssh_command (user, host, password, command): ssh_newkey = 'Are you sure you want to continue connecting' child = pexpect.spawn('ssh -l %s %s %s'%(user, host, command)) i = child.expect([pexpect.TIMEOUT, ssh_newkey, 'password: ']) if i == 0: # Timeout print 'ERROR!' print 'SSH could not login. Here is what SSH said:' print child.before, child.after return None if i == 1: # SSH does not have the public key. Just accept it. child.sendline ('yes') child.expect ('password: ') i = child.expect([pexpect.TIMEOUT, 'password: ']) if i == 0: # Timeout print 'ERROR!' print 'SSH could not login. Here is what SSH said:' print child.before, child.after return None child.sendline(password) return child def main (): host = raw_input('Hostname: ') user = raw_input('User: ') password = getpass.getpass('Password: ') for k in srvs: print 'server: ' + str(k) child = ssh_command (user, str(k), password, '/bin/bash /directory/comando.sh') child.expect(pexpect.EOF) print child.before if __name__ == '__main__': try: main() except Exception, e: print str(e) traceback.print_exc() os._exit(1)