需求是检查指定应用的某些配置因此就写了个脚本,数据文件的内容是这样的:应用名称|IP|端口 多个IP用空格,这样能够生成数组。这个文件的数据是经过部署平台的API获取后本身组装的。shell
#!/bin/bash CONFIG_PATH="temp.txt" for line in $(cat $CONFIG_PATH); do APPNAME=$(echo $line | awk -F "|" '{print $1}') IPARRAY=($(echo $line | awk -F "|" '{print $2}')) PORT=$(echo $line | awk -F "|" '{print $3}') echo $APPNAME for IP in ${IPARRAY[@]}; do echo $IP done done
脚本运行以后结果去不正确,由于在脚本中并无输出端口数组
从要处理的文件上看自己没有问题,也没有特殊字符。上面的AWK语句在命令行中均可以正常执行结果也是正确的。改变一下脚本输出看看bash
#!/bin/bash CONFIG_PATH="temp.txt" for line in $(cat $CONFIG_PATH); do APPNAME=$(echo $line | awk -F "|" '{print $1}') IPARRAY=($(echo $line | awk -F "|" '{print $2}')) PORT=$(echo $line | awk -F "|" '{print $3}') echo $APPNAME echo $IPARRAY echo $PORT # for IP in ${IPARRAY[@]}; do # echo $IP # done done
但看到这样的结果确定不对,那么就很容易联想到分隔符问题。下面看这样一个简单的例子可能更加容易明白命令行
这里明明是一行,我想输出的也是一行但是输出了三行,惟一的可能就是shell认为换行了。3d
bash shell默认将空格、制表符、换行符看作分隔符遇到这些字符shell会认为这个字符后面的是一个新的字符。因此上面就分红了3行输出。但有时候咱们但愿自定义这种分隔符来处理好比空格之类的东西,这就须要经过改变当前shell执行环境的分隔符定义。code
再次执行blog
针对最初的例子咱们也须要这样修改部署
#!/bin/bash CONFIG_PATH="temp.txt" IFS_OLD=$IFS # 保存当前IFS IFS=$'\n' # 定义新的分隔符 for line in $(cat $CONFIG_PATH); do APPNAME=$(echo $line | awk -F "|" '{print $1}') IPARRAY=($(echo $line | awk -F "|" '{print $2}')) PORT=$(echo $line | awk -F "|" '{print $3}') echo $APPNAME echo $IPARRAY echo $PORT # for IP in ${IPARRAY[@]}; do # echo $IP # done done IFS=$IFS_OLD # 恢复默认的IFS