linux批量脚本,Shell脚本

...用户名为exam1~exam30,用户密码统一为gdlclinux。

写好了,还在测试,测试好了就给你。

写好了,通过测试了。

########################################################################

#注:本脚本中使用了函数模块,以方便修改和调试

#************************************************

# 2011年12月10日初稿

#************************************************

# 2011年12月11日测试问题:密码修改函数尚未实现

#************************************************

# 2011年12月11日定稿密码修改函数实现

#************************************************

# by bmw88661@126.com 12.11.2011

########################################################################

#设置变量

i=1

username=exam

password=gdlclinux

rmso=$(tput rmso)

smso=$(tput smso)

#此处可添加要求输入用户名和密码的项

#错误判断函数

SEA()

{

location=$( which useradd)#查找useradd的绝对路径

if [\("$location"=""\)-o\(-s"$location"\) ]#判断是否找到useradd文件,或着找到的文件为空

then

echo"Useradd was not found,job terminated$smso unsuccessfully$rmso!"

exit

else

if [-x"$location" ]#若useradd文件存在且不为空,判断是否具有可执行权限

then

echo"Command useradd doesn't have excution(x) mode"

exit

else#无法确定问题原因

echo"Script terminated by some unknown problem,Please check it!"

exit

fi

fi

}

#提示信息函数

casemsg()

{

#判断passwd执行的返回值,并进入case分支

case"$y" in

0) echo"Set password for$smso$username$i$rmso successfully"

;;

1) echo"Permission denied when set password for$smso$username$i$rmso"

exit 1;;

2) echo"Invalid combination of options for command passwd"

exit 2;;

3) echo"Unexpected failure, nothing done"

exit 3;;

4) echo"Unexpected failure, passwd file missing"

exit 4;;

5) echo"Passwd file busy, try again"

exit 5;;

6) echo"Invalid argument to option"

exit 6;;

esac

}

#用户创建函数

usercreate()

{

useradd-m$username$i#如果需要其他功能,请参照useradd帮助手册修改此行,如:设置uid

x=$?

}

#密码修改函数

#这里如果你的系统里有chpasswd这个批修改工具的话,就不用这么麻烦了。

MOVpassword()

{

( echo"$password";sleep 1;echo"$password")|passwd$username$i#若useradd执行成功,则调用passwd设置密码

y=$?

}

#主循环

while ["$i"-ge 1-a"$i"-le 30 ]

do

usercreate#调用usercreate函数创建用户

if ["$x"-eq 0 ]#判断useradd是否执行成功

then

echo"User$smso$username$i$rmso have been create successfully!"

MOVpassword#调用MOVpassword修改密码

casemsg#调用casemsg函数

if ["$y"= 0 ]#如果MOVpassword的返回值为0,则将i加1

then

let i++

fi

else

SEA#调用错误判断函数

fi

done

unset i x y location rmso smso username password#释放所有设定的变量

linux下开发脚本搜索子目录批量更改文件名

前言

本文主要给大家介绍了关于Linux shell用sed批量更改文件名的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

示例

去除特定字符

目标:将 2017-01-01.jpg、2018-01-01.jpg改为 20170101.jpg、20180101.jpg

方法:将所有-替换为空

for file in `ls| grep.jpg`

do

newfile=`echo$file| sed's/-//g'`

mv$file$newfile

done

这里使用sed进行标准输出的字符串替换,其通用格式如下:

stdout| sed's/pattern/replace/'

上述示例中,在末尾添加g用于替换所有匹配项,而不仅仅替换第一个匹配项。

中间插入字符

目标:将 book01.txt、paper02.txt改为 book-01.txt、paper-02.txt

方法:用分组匹配分别获取待插入位置两侧的字符串,再通过反向引用实现替换

for file in `ls| grep.txt`

do

newfile=`echo$file| sed's/\([a-z]\+\)\([0-9]\+\)/\1-\2/'`

mv$file$newfile

done

分析

上述示例首先通过 ls和 grep命令得到待改名的文件列表,然后用 sed命令进行字符串的替换,最后再使用 mv命令来完成文件名的更改。

获取待改名文件列表的方法有很多,可以通过 find命令,也可以直接给出字符串,我们将在下文中提到。

注意 for循环后面的 ls| grep.txt,这条命令用两个反单引号括了起来,与$(ls| grep.txt)的作用相同,被包围的字符串会被当作命令执行,然后返回字符串结果。

文件名包含空格的解决方法

我们可以直接将文件列表写到 for循环中,而不是通过命令来得到,例如:

for file in"file1 file2 file3"

do

...

done

可以看到 for循环是通过空格来分割字符串,因此如果待更改的文件名中包含空格的话,就会被拆分成多个文件名,从而出错。

要解决这个问题,我们可以将 IFS(内部字段分隔符)设置为换行符\n,这样一来,for循环就会按行来获取变量的值,确保每次获取的确实是一个完整的文件名。

设置 IFS变量的命令需要放在 for循环之前:

IFS=$'\n'

for file in `ls`

do

...

done

也可以直接使用 while read命令一次读取一行到变量 file中:

ls| grep"*.txt"| while read file

do

...

done

使用 find获取文件列表

之前的示例中,我们是通过 ls命令来获取文件列表。该命令只能获取某个目录的文件,而且没法进行多种条件的筛选。

而一说到文件的查找,不得不提到功能强大的 find命令。该命令可以在多个层次的目录中查找文件,并能够设定诸如创建时间、文件大小、所有者等多种条件,查找起文件来特别方便灵活。

用 find命令来获取文件列表,再用 sed命令配合正则表达式来修改文件名,这两个命令的结合几乎能完成所有常见的批量改名任务。

例如,将所有大于1M,且后缀为txt或jpg的文件,由形如 book_20170101.txt、image_20170101.jpg的文件改名为 20170101-book.txt、20170101-image.jpg,代码如下:

for file in `find.-size+1M-name"*_*.txt"-o-name"*_*.jpg"`

do

newfile=`echo$file| sed's/\([a-z]\+\)_\([0-9]\+\)./\2-\1./'`

mv$file$newfile

done

如何控制Linux下多个Shell脚本串行执行

当你在一个类似批处理的脚本里启动多个shell脚本的时候,可能没有意识到shell背后的调度器会将这些脚本在多个CPU上并行执行。当同时执行的脚本访问某些共享资源(通常是文件)时,可能造成执行的结果错误,而且经常让你意识不到。

不同于低级语言中提供同步等机制,shell提供的逻辑执行的机制可以用于串行化执行,例如:

1.sh

&&

2.sh

&&

[...]

不过这种方法的一个问题是如果其中有一个环节返回错误,整个流程就不能进行下去。不过一般这一点不是问题,甚至这样就是我们期望的。

剩下的问题:

阅读剩余
THE END