本篇主要介绍bash脚本中对于含空格文件处理方式。
在批量处理音频文件时候使用下面的脚本发现含有空格的文件名并不能被处理;
#$1: 遍历的文件夹 rootDir=$1 cd $rootDir allAudioFile=$(find $1 -name "*.mp3") for oneAudioFile in $allAudioFile do mv -f $oneAudioFile $rootDir done
通过set -x将执行信息打印出来,发现可以执行到,但是执行过程提示找不到对应的文件名,mv对应的source文件并不是原本的文件名,通过对比发现原来是文件名中含有空格,导致在for循环的过程中并没有将完整的文件名取出来;
例如有文件a b.mp3这时候在for循环的时候会有下面的打印:
mv: cannot stat “./a” : No such file or directory
从上面的错误信息可以发现原本的文件名由于空格被打断了,因此需要在for循环处理的过程中识别到文件名是含有空格的,从而对文件名中的空格不做处理;
bash使用IFS变量进行分割,所以需要修改IFS的分隔方式进而重新隔离,即需要将"n"换行处理作为处理方式:
IFS=$(echo -en “nb”) IFS=$(echo -en “nr”)
上面的两种方式均可(使用Ubuntu16.04),其它也可以,只需要在处理的时候将"n"作为其中一个标识即可,因为使用find命令或者其他命令会将结果以行的形式存放到变量中;
#$1: 遍历的文件夹 rootDir=$1 cd $rootDir allAudioFile=$(find $1 -name "*.mp3") IFS_BACKUP=$IFS IFS=$(echo -en "nb") #IFS=$(echo -en "nr") for oneAudioFile in $allAudioFile do mv -f "$oneAudioFile" $rootDir done IFS=$IFS_BACKUP
至此,bash脚本中对于含空格文件处理方式介绍完毕,当然要记得将原本的IFS内容保存下来,脚本跑完了将原本的内容放回去。