shell脚本学习使用for循环批量解压文件
一、编写shell脚本
vim ugiz.sh
#!/bin/bash
cd /home
#首先要把要解压的文件(tar.gz格式),放入一个文件中
ls *.tar.gz > ls.log
#这样就会把所有的文件名保存到ls.log文件中
for i in $(cat ls.log) #这里可以使用linux命令catdo
tar -zxf $i & >/dev/null
done
#删除文件
rm -rf ls.log
二、批量创建数据库
vim cdatabases.sh;
#!/bin/bash
user=root
password=ailong
socket=/usr/local/mysql/mysql.sock
mycmd="mysql -u$user -p$password -S $socket"
for((i=1;i<65;i++))
do
$mycmd -e "create database db$i"
done
在执行.sh脚本时会出现
bash: ./a.sh: /bin/bash^M: bad interpreter: No such file or directory
解决办法:
什么原因呢, 我们有理由怀疑是文件格式问题? 我们用vim a.sh进入a.sh这个文件, 然后在底部模式下, 执行:set ff查看一下, 结果发现fileformat=dos, 看看, 果然是文件格式问题, 那怎么解决呢?
方法一:vim a.sh进入a.sh后, 在底部模式下, 执行:set fileformat=unix后执行:x或者:wq保存修改。 然后就可以执行./a.sh运行脚本了。(我亲自试过, 是ok的)
方法二:直接执行sed -i "s/\r//" a.sh来转化, 然后就可以执行./a.sh运行脚本了。(我亲自试过, 是ok的)
方法三:直接执行dos2unix ./a.sh来转化, 然后就可以执行./a.sh运行脚本了。(我的linux上执行dos2unix ./a.sh失败, 但是不要放弃啊, 加个busybox就可以了), 如下:
实际上, 经过上述三种方法修改后, 我们都可以再用:set ff再查一下, 发现a.sh的fileformat果然是unix了。 第三种方法最方便, 建议用第三种!
更多推荐
所有评论(0)