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了。 第三种方法最方便, 建议用第三种!
 新一代开源开发者平台 GitCode,通过集成代码托管服务、代码仓库以及可信赖的开源组件库,让开发者可以在云端进行代码托管和开发。旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。
更多推荐


所有评论(0)