python批量修改ssh密碼的實(shí)現(xiàn)
由于工作需要本文主結(jié)合了excel表格,對(duì)表格中的ssh密碼進(jìn)行批量修改
以下是詳細(xì)代碼(python3):
''' 遇到問題沒人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:857662006 尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書! ''' #!/usr/bin/env python #-*-coding:utf-8-*- import paramiko import socket import pandas as pd def demo(Ip,user,old_password,new_password): # 建立一個(gè)sshclient對(duì)象 ssh = paramiko.SSHClient() # 允許將信任的主機(jī)自動(dòng)加入到host_allow 列表,此方法必須放在connect方法的前面 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 調(diào)用connect方法連接服務(wù)器 #如果遠(yuǎn)程執(zhí)行命令錯(cuò)誤信息是b'the input device is not a TTY\n' 去掉docker exec -it 中的t就好了 try: ssh.connect(hostname=Ip, port=22, username=user, password=old_password,timeout=5) #ubuntu修改密碼兩種方法 #方法一 # command1 = "echo '%s:%s' | chpasswd"%(user,new_password) # stdin, stdout, stderr = ssh.exec_command(command1) # out, err = stdout.read(), stderr.read() # if err != '': # print(err) # # else: # print(out) # # 關(guān)閉連接 # ssh.close() #方法二 command = "passwd %s" %(user) stdin, stdout, stderr = ssh.exec_command(command) #\n模擬回車 輸兩次密碼 stdin.write(new_password + '\n' + new_password + '\n') out, err = stdout.read(), stderr.read() successful = 'password updated successfully' #print(out,err) if successful in str(err): print(Ip + " 密碼修改成功!") else: print('\033[31m錯(cuò)誤:\033[0m' + str(err)) print(Ip + " 密碼修改失敗!") # 關(guān)閉連接 ssh.close() except paramiko.ssh_exception.AuthenticationException as e: print(Ip + ' ' + '\033[31m賬號(hào)密碼錯(cuò)誤!\033[0m') with open('nossh.txt','a') as f: f.write(Ip + '\n') except socket.timeout as e: print(Ip + ' ' + '\033[31m連接超時(shí)!\033[0m') with open('timeoutssh','a') as f: f.write(Ip + '\n') def Red_Excel(IP): import sys import time file = r'E:\xxx.xlsx' pd.set_option('display.max_columns', None) pd.set_option('display.max_colwidth', 1000) n = pd.read_excel(file,sheet_name='xxx') #表格中的sheet名 #print(n.values) #顯示含某字段的特定行 n1 = (n.loc[n['IP']==IP]) if not n1.empty: n2 = n1.values ip = n2[0][1] user = n2[0][4] password_old = n2[0][5] password_new = n2[0][22] houtai = n2[0][16] print('IP:%s 賬號(hào):%s 舊密碼:%s 是否后臺(tái):%s 新密碼:%s' % (ip, user, password_old, houtai,password_new)) demo(ip,user,password_old,password_new) else: print('記錄表無此IP!') if __name__ == "__main__": with open('ip.txt') as f: for i in f: ip = i.split('\n')[0] Red_Excel(ip)
此代碼可以適當(dāng)修改,進(jìn)行單獨(dú)的ssh密碼修改。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python 實(shí)現(xiàn)將小圖片放到另一個(gè)較大的白色或黑色背景圖片中
今天小編就為大家分享一篇python 實(shí)現(xiàn)將小圖片放到另一個(gè)較大的白色或黑色背景圖片中,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12Python編寫簡化版的文字冒險(xiǎn)游戲的實(shí)例代碼
Python編寫簡化版的文字冒險(xiǎn)游戲:迷失的寶藏,這個(gè)文字冒險(xiǎn)游戲包含了游戲開發(fā)的基本要素:游戲狀態(tài)管理、玩家輸入處理、游戲邏輯和循環(huán),通過擴(kuò)展游戲的內(nèi)容和功能,可以制作出更復(fù)雜、更有趣的游戲,希望這個(gè)實(shí)例代碼能夠激發(fā)你對(duì)游戲編程的興趣和創(chuàng)造力!2024-05-05python將字母轉(zhuǎn)化為數(shù)字實(shí)例方法
在本篇文章里小編給大家整理的是關(guān)于python如何將字母轉(zhuǎn)化為數(shù)字的相關(guān)實(shí)例內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2019-10-10Python實(shí)現(xiàn)為PDF大文件批量去除水印
在閱讀過程中如果遇到一些帶有水印的資料是比較煩心的,而市面上去水印的功能有多要收費(fèi)且很不方便,那么,如何通過Python來對(duì)這類圖片水印進(jìn)行去除呢,本文就來和大家分享一下實(shí)現(xiàn)方法吧2023-05-05Python純代碼通過神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)線性回歸的擬合方式
這篇文章主要介紹了Python純代碼通過神經(jīng)網(wǎng)絡(luò)實(shí)現(xiàn)線性回歸的擬合方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05深入分析python數(shù)據(jù)挖掘 Json結(jié)構(gòu)分析
這篇文章通過實(shí)例給大家分析總結(jié)了python數(shù)據(jù)挖掘以及Json結(jié)構(gòu)分析的相關(guān)知識(shí)點(diǎn),對(duì)此有興趣的朋友參考下。2018-04-04