码迷,mamicode.com
首页 > 编程语言 > 详细

批量修改Linux密码脚本(Python)

时间:2020-06-08 14:35:32      阅读:86      评论:0      收藏:0      [点我收藏+]

标签:环境   工具   home   centos 7   log   git   修改时间   uda   centos   

搭建环境
centos 7.4
使用脚本
python
批量修改connect用户的密码
生成密码为随机密码 保存为xls文档
 
#!/usr/bin/env python
# -*- coding: utf-8 -*-
############################################
#通过脚本批量修改Linux主机密码并保存到xls中
#雪文龙 2018-5-18 V1
#
#修改者:xxx
#修改时间:2018-xx-xx 
#修改内容:修改内容描述
############################################

import random
import string,os
import pexpect
import xlrd,xlwt
from xlwt import Style
from xlutils.copy import copy
 
def passwd_creat():
    salt = ‘‘.join(random.sample(string.ascii_letters + string.digits, 8))
    return salt
 
def passwd_change(userip, oldpasswd, newpasswd):
    child = pexpect.spawn(‘ssh connect@‘+userip)                 ###connect 用户可改root
    fout = file(‘/home/shell/passwd/newpasslog.txt‘,‘a‘)            ##定义日志文件,
    child.logfile = fout
    index = child.expect([‘password:‘,‘continue connecting (yes/no)?‘])
    if index == 0:
        child.sendline(oldpasswd)
    elif index == 1:
        child.sendline(‘yes‘)
        child.expect(‘password:‘)
        child.sendline(oldpasswd)
    child.expect(‘$‘)
    child.sendline(‘sudo -i‘)
    child.expect(‘#‘)
    child.sendline(‘echo ‘+newpasswd+‘ | passwd --stdin connect‘)   ### connect 用户可改root
    child.expect(‘#‘)
    child.sendline(‘exit‘)
 
def open_excel(passwdfile):
    data = xlrd.open_workbook(passwdfile)
    return data
 
def get_coldata(passwdfile,sheet_name,num):
    data = open_excel(passwdfile)
    table = data.sheet_by_name(sheet_name)
    coldata = table.row_values(num)
    return coldata
 
def get_rownum(passwdfile,sheet_name):
    data = open_excel(passwdfile)
    table = data.sheet_by_name(sheet_name)
    rowsNum = table.nrows  #获取总行数
    colsNum = table.ncols   #获取总列数
    return rowsNum,colsNum
 
def add_newpwd(row, col, str):
    rb = xlrd.open_workbook(passwdfile, formatting_info=True)
    wb = copy(rb)
    ws = wb.get_sheet(0)
    ws.write(row, col, str)
    wb.save(passwdfile)
 
 
if __name__ == "__main__":
    passwdfile = "/home/shell/passwd/newpasswd.xls"     #文档读取输出路径
    sheet_name = "Sheet1"
    rowsNum, colsNum = get_rownum(passwdfile,sheet_name)
    add_newpwd(0,colsNum,‘newpasswd‘)
    for i in range(1,rowsNum):
        newpasswd = passwd_creat()
        coldata = get_coldata(passwdfile,sheet_name,i)
        passwd_change(coldata[0], coldata[1], newpasswd)
        add_newpwd(i,colsNum,newpasswd)

  

 
 
1. 上传脚本,以及脚本需要的模块
1.1 创建转到脚本,模块包存放地址。
技术图片
1.2安装上传工具。
技术图片
1.3上传模块包脚本。
技术图片
rz上传
sz下载
技术图片
2.安装所需要的模块。
2.1 解压gz包。
技术图片
2.2 cd到解压文件目录下
技术图片
2.3 执行脚本安装模块
技术图片
目录下的所有gz包都要安装过程略过
技术图片
3.执行脚本测试实验。
3.1创建一个connect用户并设置密码。并登陆测试。
技术图片
 
技术图片
3.2创建文档(文档名需要和脚本里的名称一样)
技术图片
3.3上传文档到定义的路径下
技术图片
 
技术图片
3.4执行脚本测试
技术图片
3.5
sz下载表格查看密码
技术图片
 
技术图片
3.6 使用新密码登陆测试
技术图片
 
 
 

批量修改Linux密码脚本(Python)

标签:环境   工具   home   centos 7   log   git   修改时间   uda   centos   

原文地址:https://www.cnblogs.com/xuewenlong/p/13065234.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!