来源说明:《跟老男孩学Linux运维》Shell编程实战
说明:对于每个脚本,用shell编程的同时,我再用python实现,达到同时熟悉两种脚本语言的目的。由于初学python,有问题还请大家斧正。
面试题1:批量生产随机字符文件名
用shell实现
代码:
root@vmUbu:/home/dell/shell# vim creat_ten_htmlfile.sh #!/bin/bash #Date: 2017-8-25 #Author: XianWei Path=/tmp/shelltmp [ -d "$Path" ] || mkdir -p $Path #如果测试结果为假,就执行mkdir语句 cd $Path for((i=0;i<10;i++)) #循环执行10次 do namepre=`date +%s|md5sum|tr -dc "a-z"` #生成随机的10个字母 namepost='_oldboy.html' #文件名的后缀 filename=${namepre}${namepost} #字符串连接 touch $filename echo "$filename have been created." sleep 1 done & wait
测试
root@vmUbu:/home/dell/shell# ./creat_ten_htmlfile.sh adcaeeafbc_oldboy.html have been created. ecbdeabdaedceb_oldboy.html have been created. edffdbddee_oldboy.html have been created. beadcabbbdcbdb_oldboy.html have been created. fcaadeaedafbc_oldboy.html have been created. adddadbc_oldboy.html have been created. bcadafebdabe_oldboy.html have been created. deffebcd_oldboy.html have been created. fafbbcdcfcfecef_oldboy.html have been created. fbfdedccbcc_oldboy.html have been created. root@vmUbu:/home/dell/shell# root@vmUbu:/home/dell/shell# ll /tmp/shelltmp/ total 8 drwxr-xr-x 2 root root 4096 Aug 25 07:53 ./ drwxrwxrwt 15 root root 4096 Aug 25 08:05 ../ -rw-r--r-- 1 root root 0 Aug 25 07:53 adcaeeafbc_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 adddadbc_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 bcadafebdabe_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 beadcabbbdcbdb_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 deffebcd_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 ecbdeabdaedceb_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 edffdbddee_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 fafbbcdcfcfecef_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 fbfdedccbcc_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 07:53 fcaadeaedafbc_oldboy.html
总结:
考察知识点:
1)生成随机数的方法
2)字符串连接的方法
使用Python实现
代码
#encoding:utf-8 import random import os def get10char(): #create 10 random charactors seed = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" sa = [] for i in xrange(10): sa.append(random.choice(seed)) salt = ''.join(sa) return salt def createfile(name): path="/tmp/shelltmp/" #check whether the dir is exists,if not create it if os.path.exists(path) != True: os.mkdir(path) pathAndName=path+name with open(pathAndName,"wb") as f: #create file pass if os.path.exists(pathAndName): print "%s have been created" %name #print the result else: print "create file failed,Please check it." def main(): for i in xrange(10): #loop 10 times to create 10 file filename=get10char()+"_oldboy.html" createfile(filename) if __name__ == "__main__": main()
面试题2:将面试题1中的字符串oldboy全部改为oldgirl
方法一:使用awk生成所需命令,再用bash执行
代码和测试:
root@vmUbu:/tmp/shelltmp# for i in `ls /tmp/shelltmp`;do echo $i|awk -F "_" '{print "mv " $0 " " $1"_oldgirl.html" }' |bash ;done root@vmUbu:/tmp/shelltmp# ls adcaeeafbc_oldgirl.html beadcabbbdcbdb_oldgirl.html edffdbddee_oldgirl.html fcaadeaedafbc_oldgirl.html adddadbc_oldgirl.html deffebcd_oldgirl.html fafbbcdcfcfecef_oldgirl.html bcadafebdabe_oldgirl.html ecbdeabdaedceb_oldgirl.html fbfdedccbcc_oldgirl.html root@vmUbu:/tmp/shelltmp#
方法2:使用sed替换文件名,再用mv修改文件名
代码
#!/bin/bash #Date: 2017-8-25 #Author: XianWei Path=/tmp/shelltmp [ -d "$Path" ] || exit 0 #如果测试结果为假,就执行mkdir语句 cd $Path for oldfile in `ls $Path/ |grep oldboy` do newfile=`echo $oldfile | sed s/oldboy/oldgirl/g` #生成新的文件名 mv $oldfile $newfile done & wait
测试
root@vmUbu:/home/dell/shell# python 1_creat_ten_htmlfile.py WKfqYfUprf_oldboy.html have been created QplbhAZVZA_oldboy.html have been created jmkkmepTfD_oldboy.html have been created IAeFZLHzOj_oldboy.html have been created DwWbMsCqtN_oldboy.html have been created ZgAVXNCyLQ_oldboy.html have been created DBENsfnZpv_oldboy.html have been created PveegnMyBo_oldboy.html have been created MpReSrwXJr_oldboy.html have been created SWWFrkYhdi_oldboy.html have been created root@vmUbu:/home/dell/shell# root@vmUbu:/home/dell/shell# ll /tmp/shelltmp/ total 8 drwxr-xr-x 2 root root 4096 Aug 25 11:32 ./ drwxrwxrwt 16 root root 4096 Aug 25 11:32 ../ -rw-r--r-- 1 root root 0 Aug 25 11:32 DBENsfnZpv_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 DwWbMsCqtN_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 IAeFZLHzOj_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 jmkkmepTfD_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 MpReSrwXJr_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 PveegnMyBo_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 QplbhAZVZA_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 SWWFrkYhdi_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 WKfqYfUprf_oldboy.html -rw-r--r-- 1 root root 0 Aug 25 11:32 ZgAVXNCyLQ_oldboy.html root@vmUbu:/home/dell/shell#
python实现
代码
#encoding:utf-8 import random import os import sys def main(): path="/tmp/shelltmp/" if os.path.exists(path) !=True: #check the dir whether exists print "%s not exists,check it." %path sys.exit(1) for root,dir,file in os.walk(path): #put the dest file into a list pass for oldfilename in file: if oldfilename.split("_")[1] == "oldboy.html": #if filename include strings "oldboy",change its name newfilename = oldfilename.split("_")[0]+"_oldgirl.html" os.rename(path+oldfilename,path+newfilename) #change name if os.path.exists(path+newfilename): #print the result print "%s have been change name to %s" %(oldfilename,newfilename) else: print "%s changed name failed." %(oldfilename) if __name__ == "__main__": main()
测试
root@vmUbu:/home/dell/shell# ls /tmp/shelltmp/ COFoqgRped_oldboy.html FnlInKOFDD_oldboy.html KraoAAesrC_oldboy.html LFCkswpeJc_oldboy.html RXwWPTAYTF_oldboy.html dxTHbQyYyZ_oldboy.html ickDGJUVgD_oldboy.html LBbLaTnuRW_oldboy.html ReFkjxYZjO_oldboy.html tKwmVefsCP_oldboy.html root@vmUbu:/home/dell/shell# python 2_change_name.py LFCkswpeJc_oldboy.html have been change name to LFCkswpeJc_oldgirl.html dxTHbQyYyZ_oldboy.html have been change name to dxTHbQyYyZ_oldgirl.html FnlInKOFDD_oldboy.html have been change name to FnlInKOFDD_oldgirl.html RXwWPTAYTF_oldboy.html have been change name to RXwWPTAYTF_oldgirl.html COFoqgRped_oldboy.html have been change name to COFoqgRped_oldgirl.html ReFkjxYZjO_oldboy.html have been change name to ReFkjxYZjO_oldgirl.html LBbLaTnuRW_oldboy.html have been change name to LBbLaTnuRW_oldgirl.html tKwmVefsCP_oldboy.html have been change name to tKwmVefsCP_oldgirl.html KraoAAesrC_oldboy.html have been change name to KraoAAesrC_oldgirl.html ickDGJUVgD_oldboy.html have been change name to ickDGJUVgD_oldgirl.html root@vmUbu:/home/dell/shell# ls /tmp/shelltmp/ COFoqgRped_oldgirl.html FnlInKOFDD_oldgirl.html KraoAAesrC_oldgirl.html LFCkswpeJc_oldgirl.html RXwWPTAYTF_oldgirl.html dxTHbQyYyZ_oldgirl.html ickDGJUVgD_oldgirl.html LBbLaTnuRW_oldgirl.html ReFkjxYZjO_oldgirl.html tKwmVefsCP_oldgirl.html root@vmUbu:/home/dell/shell#
面试题3:批量创建用户和密码
代码
root@vmUbu:/home/dell/shell# vim 3_create_user.sh #!/bin/bash #Date: 2017-8-25 #Author: XianWei #create ten users in bulk for((i=0;i<=10;i++)) do username="oldboy${i}" #cannot use symbol '' password=`tr -dc "a-zA-Z0-9" > passwd.txt #record the username and it's password done
测试
root@vmUbu:/home/dell/shell# ./3_create_user.sh root@vmUbu:/home/dell/shell# cat /etc/passwd ...... hello:x:1001:1001::/home/hello: oldboy0:x:1002:1002::/home/oldboy0: oldboy1:x:1003:1003::/home/oldboy1: oldboy2:x:1004:1004::/home/oldboy2: oldboy3:x:1005:1005::/home/oldboy3: oldboy4:x:1006:1006::/home/oldboy4: oldboy5:x:1007:1007::/home/oldboy5: oldboy6:x:1008:1008::/home/oldboy6: oldboy7:x:1009:1009::/home/oldboy7: oldboy8:x:1010:1010::/home/oldboy8: oldboy9:x:1011:1011::/home/oldboy9: oldboy10:x:1012:1012::/home/oldboy10: root@vmUbu:/home/dell/shell# #查看密码文件 root@vmUbu:/home/dell/shell# cat passwd.txt oldboy0 Je28ZqTi oldboy1 LcA5AX3u oldboy2 QF36POh2 oldboy3 5BMoklFp oldboy4 18slv8fB oldboy5 8eIVWck3 oldboy6 ZuWQcqjT oldboy7 lSeahDHM oldboy8 XvqBiFPA oldboy9 VNc8fLZC oldboy10 zdbruc2S
python实现
代码
#encoding:utf-8 ''' #date: 2017-8-26 #Author: XianWei from ChengDu #scripte Function: create users and set its password in bulk ''' import random import os import sys import subprocess import random def get_passwd(n): passwdlist=[] seed="abcdefghijkmnopqrstuvwxyz" for j in xrange(n): passwdlist.append(random.choice(seed)) passwd = "".join(passwdlist) return passwd def create_user(user): create_user_cmd = 'useradd %s ' %user p = subprocess.Popen(args=create_user_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, close_fds=True) returncode = p.wait() if returncode == 0: print "useradd %s succussful" %user password=get_passwd(8) set_passwd_cmd = 'echo %s:%s |chpasswd' %(user,password) p2 = subprocess.Popen(args=set_passwd_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT, close_fds=True) returncode_p2 = p2.wait() if returncode_p2 == 0: print "%s set password succussful.its password : %s" %(user,password) else: print "sorry,set password failed!" else: print "useradd failed." sys.exit(1) def main(): userlist = [] for i in xrange(1,11): userlist.append("oldgirl"+str(i)) for user in userlist: create_user(user) if __name__ == "__main__": main()
测试
root@vmUbu:/home/dell/shell# python 3_create_user.py useradd oldgirl1 succussful oldgirl1 set password succussful.its password : qtcvheyq useradd oldgirl2 succussful oldgirl2 set password succussful.its password : wnaecfxu useradd oldgirl3 succussful oldgirl3 set password succussful.its password : wpxwtcvv useradd oldgirl4 succussful oldgirl4 set password succussful.its password : cpquxwzd useradd oldgirl5 succussful dgirl5 set password succussful.its password : gdtmttug useradd oldgirl6 succussful oldgirl6 set password succussful.its password : eznjdjow useradd oldgirl7 succussful oldgirl7 set password succussful.its password : eysxegpu useradd oldgirl8 succussful oldgirl8 set password succussful.its password : yhdkrdyb useradd oldgirl9 succussful oldgirl9 set password succussful.its password : omytwhdh useradd oldgirl10 succussful oldgirl10 set password succussful.its password : zpenokqg root@vmUbu:/home/dell/shell# root@vmUbu:/home/dell/shell# cat /etc/passwd |grep oldgirl oldgirl1:x:1013:1013::/home/oldgirl1: oldgirl2:x:1014:1014::/home/oldgirl2: oldgirl3:x:1015:1015::/home/oldgirl3: oldgirl4:x:1016:1016::/home/oldgirl4: oldgirl5:x:1017:1017::/home/oldgirl5: oldgirl6:x:1018:1018::/home/oldgirl6: oldgirl7:x:1019:1019::/home/oldgirl7: oldgirl8:x:1020:1020::/home/oldgirl8: oldgirl9:x:1021:1021::/home/oldgirl9: oldgirl10:x:1022:1022::/home/oldgirl10: root@vmUbu:/home/dell/shell#
面试题4:扫描网络内存活主机
代码
#!/bin/bash #Date: 2017-8-26 #Author: XianWei #check the server whether is alive ippre='192.168.142.' cmd='ping -c2 ' for((i=0;i<=20;i++)) do { $cmd $ippre$i > /dev/null 2&>1 if [ $? -eq 0 ] then echo "$ippre$i is ok" else echo "$ippre$i is down" fi }& #parallel progress done wait #let parent progress wait all child progress
测试
root@vmUbu:/home/dell/shell# time ./4_ping_host.sh 192.168.142.0 is down 192.168.142.2 is ok 192.168.142.11 is down 192.168.142.20 is down 192.168.142.4 is down 192.168.142.12 is down 192.168.142.3 is down 192.168.142.9 is down 192.168.142.18 is down 192.168.142.5 is down 192.168.142.15 is down 192.168.142.13 is down 192.168.142.16 is down 192.168.142.17 is down 192.168.142.10 is down 192.168.142.14 is down 192.168.142.6 is down 192.168.142.19 is down 192.168.142.1 is down 192.168.142.7 is down 192.168.142.8 is down real 0m11.229s user 0m0.024s sys 0m0.720s
python实现
代码
# encoding:utf-8 ''' #date: 2017-8-26 #Author: XianWei from ChengDu #scripte Function: check ip whether is alived in bulk ''' import random import os import sys import subprocess import random import platform import re from threading import Thread from Queue import Queue import time def check_ip(ipaddr): #函数用于检测IP地址合法性。来源:http://blog.csdn.net/jbxue123/article/details/23156011 addr=ipaddr.strip().split('.') #切割IP地址为一个列表 #print addr if len(addr) != 4: #切割后列表必须有4个参数 print "%s,ip address is illegal!" %ipaddr return False for i in range(4): try: addr[i]=int(addr[i]) #每个参数必须为数字,否则校验失败 except: print "%s,ip address is illegal!" % ipaddr return False if addr[i]<=255 and addr[i]>=0: #每个参数值必须在0-255之间 pass else: print "%s,ip address is illegal!" % ipaddr return False #print "check ip address success!" return True def ping_host(ip): if check_ip(ip) == False: #检测IP合法性 sys.exit(1) platformOfSystem = platform.system() #根据平台,设置ping命令 if (platformOfSystem == "Windows"): cmd = "ping -n 2 %s" % (ip) if (platformOfSystem == "Linux"): cmd = "ping -c 2 %s" % (ip) res = os.popen(cmd) if (platform.system() == "Windows"): if (re.findall("Lost = 2", res.read()).__len__() != 0): print "%s is down." % ip else: print "%s is OK." % ip if (platform.system() == "Linux"): pingResult = re.findall("Destination Host Unreachable", res.read()) if (pingResult.__len__() != 0): print "%s is down." % ip else: print "%s is OK." % ip def main(): print "main threading waiting......" ip_prefix = "192.168.142." #设置ip列表 iplist = [] n = 10 for i in xrange(1,n + 1): iplist.append(ip_prefix + str(i)) tlist = [] for i in xrange(len(iplist)): #使用多线程ping t = Thread(target=ping_host, args=(iplist[i],)) #将线程加入list tlist.append(t) for thread in tlist: #启动所有线程 thread.setDaemon(True) thread.start() for thread in tlist: #等待所有线程结束 thread.join() print "main threading Done" if __name__ == "__main__": main()
linux平台测试
root@vmUbu:/home/dell/shell# time python 4_ping_host.py main threading waiting...... 192.168.142.1 is OK. 192.168.142.2 is OK. 192.168.142.3 is down. 192.168.142.6 is down. 192.168.142.4 is down. 192.168.142.5 is down. 192.168.142.7 is down. 192.168.142.8 is down. 192.168.142.9 is down. 192.168.142.10 is down. main threading Done real 0m3.166s user 0m0.100s sys 0m0.296s root@vmUbu:/home/dell/shell#
windows平台测试
C:\Users\Administrator\PycharmProjects\shell_to_python\0826>python changename.py main threading waiting...... 192.168.142.1 is OK. 192.168.142.3 is down. 192.168.142.6 is down. 192.168.142.9 is down. 192.168.142.4 is down. 192.168.142.7 is down. 192.168.142.8 is down. 192.168.142.5 is down. 192.168.142.2 is OK.192.168.142.10 is down. main threading Done
面试题10:比较两个数大小
要求:输入两个数,比较大小并输出结果
代码
#!/bin/bash #Date: 2017-8-27 #Author: XianWei #作用:输入两个数,比较大小并输出结果 #判断输入的是否为数字 function judgenum() { if [ $1 -gt -99999999 ] > /dev/null 2>&1 #与一个很小的数比较 then echo -n else echo "Error,Please input a number" exit fi } read -p "Please input the first number:" num1 judgenum $num1 read -p "Please input the second number:" num2 judgenum $num2 let res=$num1-$num2 echo $res [ $res -gt 0 ] && echo "$num1 > $num2" [ $res -lt 0 ] && echo "$num1 < $num2" [ $res -eq 0 ] && echo "$num1 = $num2"
测试
dell@vmUbu:~/shell$ bash judgenum.sh Please input the first number:1 Please input the second number:b Error,Please input a number dell@vmUbu:~/shell$ bash judgenum.sh Please input the first number:a Error,Please input a number dell@vmUbu:~/shell$ dell@vmUbu:~/shell$ dell@vmUbu:~/shell$ dell@vmUbu:~/shell$ bash judgenum.sh Please input the first number:2 Please input the second number:2 2 = 2 dell@vmUbu:~/shell$ bash judgenum.sh Please input the first number:2 Please input the second number:3 2 < 3 dell@vmUbu:~/shell$ bash judgenum.sh Please input the first number:2 Please input the second number:1 2 > 1 dell@vmUbu:~/shell$
知识点
1)如何判断输入的是一个整数。除了本例中的方法还可以使用expr,比如expr num + 1,如果返回值$?为0表示输入的是一个数。否则不是一个数,返回错误并退出
使用Python实现
代码
# encoding:utf-8 import sys num1 = raw_input() try: num1 = int(num1) except: print "Error ,please input a number." sys.exit(2) num2 = raw_input() try: num2 = int(num2) except: print "Error ,please input a number." sys.exit(2) if(num1>num2): print "%d>%d" %(num1,num2) else: if(num1
未完待续.......