python批量修改ssh密码的实现


Posted in Python onAugust 08, 2019

由于工作需要本文主结合了excel表格,对表格中的ssh密码进行批量修改

以下是详细代码(python3):

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
#!/usr/bin/env python
#-*-coding:utf-8-*-

import paramiko
import socket
import pandas as pd

def demo(Ip,user,old_password,new_password):
  # 建立一个sshclient对象
  ssh = paramiko.SSHClient()
  # 允许将信任的主机自动加入到host_allow 列表,此方法必须放在connect方法的前面
  ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
  # 调用connect方法连接服务器
  #如果远程执行命令错误信息是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)
    # # 关闭连接
    # 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错误:\033[0m' + str(err))
      print(Ip + " 密码修改失败!")
    # 关闭连接
    ssh.close()
  except paramiko.ssh_exception.AuthenticationException as e:
    print(Ip + ' ' + '\033[31m账号密码错误!\033[0m')
    with open('nossh.txt','a') as f:
      f.write(Ip + '\n')
  except socket.timeout as e:
    print(Ip + ' ' + '\033[31m连接超时!\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 账号:%s 旧密码:%s 是否后台:%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)

此代码可以适当修改,进行单独的ssh密码修改。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Ruby元编程基础学习笔记整理
Jul 02 Python
Python中使用platform模块获取系统信息的用法教程
Jul 08 Python
详解Python map函数及Python map()函数的用法
Nov 16 Python
对Python通过pypyodbc访问Access数据库的方法详解
Oct 27 Python
python 实现多维数组转向量
Nov 30 Python
Python操作redis和mongoDB的方法
Dec 19 Python
Pytorch: 自定义网络层实例
Jan 07 Python
Python猜数字算法题详解
Mar 01 Python
基于opencv实现简单画板功能
Aug 02 Python
python切割图片的示例
Nov 12 Python
python生成随机数、随机字符、随机字符串
Apr 06 Python
浅析Python中的随机采样和概率分布
Dec 06 Python
更新pip3与pyttsx3文字语音转换的实现方法
Aug 08 #Python
Python使用百度翻译开发平台实现英文翻译为中文功能示例
Aug 08 #Python
python按行读取文件并找出其中指定字符串
Aug 08 #Python
python实现PID算法及测试的例子
Aug 08 #Python
python开头的coding设置方法
Aug 08 #Python
pycharm 安装JPype的教程
Aug 08 #Python
Python学习笔记之lambda表达式用法详解
Aug 08 #Python
You might like
屏蔽浏览器缓存另类方法
2006/10/09 PHP
有道搜索和IP138的IP的API接口(PHP应用)
2012/11/29 PHP
php+xml编程之SimpleXML的应用实例
2015/01/24 PHP
php实现保存周期为1天的购物车类
2017/07/07 PHP
ExtJs的Date格式字符代码
2010/12/30 Javascript
jqGrid jQuery 表格插件测试代码
2011/08/23 Javascript
jQuery的live()方法对hover事件的处理示例
2014/02/27 Javascript
js判断url是否有效的两种方法
2014/03/04 Javascript
js获取元素外链样式的方法
2015/01/27 Javascript
JS组件Bootstrap Table使用方法详解
2016/02/02 Javascript
灵活的理解JavaScript中的this指向
2016/02/25 Javascript
jquery遍历标签中自定义的属性方法
2016/09/17 Javascript
浅谈js中几种实用的跨域方法原理详解
2016/12/02 Javascript
jQuery插件echarts实现的去掉X轴、Y轴和网格线效果示例【附demo源码下载】
2017/03/04 Javascript
vue-cli3添加模式配置多环境变量的方法
2019/06/05 Javascript
Vue状态模式实现窗口停靠功能(灵动、自由, 管理后台Admin界面)
2020/03/06 Javascript
JavaScript进阶(二)词法作用域与作用域链实例分析
2020/05/09 Javascript
vscode中的vue项目报错Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)
2020/09/11 Javascript
three.js中多线程的使用及性能测试详解
2021/01/07 Javascript
[01:28]一分钟告诉你DOTA2 TI9不朽宝藏Ⅱ中有什么!
2019/07/09 DOTA
跟老齐学Python之再深点,更懂list
2014/09/20 Python
django模板语法学习之include示例详解
2017/12/17 Python
flask框架视图函数用法示例
2018/07/19 Python
python3 拼接字符串的7种方法
2018/09/12 Python
Python字典的核心底层原理讲解
2019/01/24 Python
django自定义非主键自增字段类型详解(auto increment field)
2020/03/30 Python
jupyter notebook 重装教程
2020/04/16 Python
pip 20.3 新版本发布!即将抛弃 Python 2.x(推荐)
2020/12/16 Python
护士自我鉴定
2013/10/23 职场文书
联欢晚会主持词
2014/03/25 职场文书
会议接待欢迎标语
2014/10/08 职场文书
2015年体检中心工作总结
2015/05/27 职场文书
运动会100米加油稿
2015/07/21 职场文书
初中思品教学反思
2016/02/20 职场文书
浅谈Python基础之列表那些事儿
2021/05/11 Python
解决MySQL报“too many connections“错误
2022/04/19 MySQL