El separador de campo de cadena de secuencia de comandos de shell de Linux se almacena en la matriz de acuerdo con el valor del subíndice

Campo separado por coma

[root@oracle low]# cat test1.sh 
#!/bin/bash

txt='123,456,789'
   ifs_old=$IFS
   IFS=$','
   for i in $(echo "${txt}")
   do
   echo "${i}"
   done
[root@oracle low]# bash test1.sh 
123
456
789
[root@oracle low]# 

Ponga el valor en la matriz de acuerdo con el subíndice

[root@oracle low]# cat test1.sh 
#!/bin/bash

txt='123,456,789'
   ifs_old=$IFS
   IFS=$','
         arr=($txt)
      #根据数组下标取值
        echo "这是下标为0的:${arr[0]}"
        echo "这是下标为1的:${arr[1]}"
        echo "这是下标为2的:${arr[2]}"
     

[root@oracle low]# bash test1.sh 
这是下标为0的:123
这是下标为1的:456
这是下标为2的:789

Avanzado:

#!/bin/bash
#循环读文件
for line in `cat ./FilePath`
do
        #要将$a分割开,先存储旧的分隔符
        OLD_IFS="$line"
        #设置分隔符
        IFS="," 
        #如下会自动分隔 加入数组
        arr=($line)
        #根据数组下标判断文件是否存在
        if [[ ! -f /data/www/flowbilling/${arr[0]} ]];then
                #不存在则记录日志  更改路径为从服务器存放路径  后期手动更改文件名 chwj变量 改为 chfile变量
                echo "/home/www/123t/123/${arr[0]},${arr[1]},${arr[2]},${arr[3]}" >> 123.txt
        #如果文件路径存在,将其放入新路径
        else 
                mkdir /data/www/flowbilling/123/${arr[1]}/${arr[2]}/${arr[3]}/${arr[0]%/*} -p
                #复制原文件 到新目录下
                cp /data/www/flowbilling/${arr[0]} /data/www/flowbilling/123/${arr[1]}/${arr[2]}/${arr[3]}/${arr[0]}
        fi
done

Supongo que te gusta

Origin blog.csdn.net/weixin_44578029/article/details/111277095
Recomendado
Clasificación