博客
关于我
shell取值分割后的每个字段赋值给变量
阅读量:88 次
发布时间:2019-02-25

本文共 1038 字,大约阅读时间需要 3 分钟。

比如

a="www.baidu.com A 300 192.168.1.1"

想要拿到ttl 300和IP地址 192.168.1.1并可能后面需要传递给其他命令做DNS的删除和添加

#!/bin/bashdeclare -a arrindex=0a="www.baidu.com A 300 192.168.1.1"for i in $(echo "$a" | awk '{print $3,$4}')do    arr[$index]=$i    (( "index+=1" ))doneecho "ttl"echo "${arr[0]}"echo "ip address "echo "${arr[1]}"# 方法二:通过eval+赋值的方式b=""c=""eval "$(echo "$a" | awk '{ printf("b=%s;c=%s",$3,$4)}')"echo "$b"echo "$c"

参考下:菜鸟教程理解下这个

#!/bin/bash# author:菜鸟教程# url:www.runoob.com#我们也可以使用下标来定义数组:array_name[0]=value0array_name[1]=value1array_name[2]=value2#读取数组元素值的一般格式是:#${array_name[index]}my_array=(A B "C" D)echo "第一个元素为: ${my_array[0]}"echo "第二个元素为: ${my_array[1]}"echo "第三个元素为: ${my_array[2]}"echo "第四个元素为: ${my_array[3]}"my_array[0]=Emy_array[1]=Fmy_array[2]=Gmy_array[3]=H#使用@ 或 * 可以获取数组中的所有元素,例如echo "数组的元素为: ${my_array[*]}"echo "数组的元素为: ${my_array[@]}"#获取数组长度的方法与获取字符串长度的方法相同,例如:echo "数组元素个数为: ${#my_array[*]}"echo "数组元素个数为: ${#my_array[@]}"执行 结果 ./shuzu.sh第一个元素为: A第二个元素为: B第三个元素为: C第四个元素为: D数组的元素为: E F G H数组的元素为: E F G H数组元素个数为: 4数组元素个数为: 4

转载地址:http://tca.baihongyu.com/

你可能感兴趣的文章
Navicat for MySQL笔记1
查看>>
Navicat for MySQL(Ubuntu)过期解决方法
查看>>
Navicat Premium 12 卸载和注册表的删除
查看>>
Navicat 导入sql文件
查看>>
navicat 添加外键1215错误
查看>>
navicat 系列软件一点击菜单栏就闪退
查看>>
navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
查看>>
Navicat 设置时间默认值(当前最新时间)
查看>>
navicat 连接远程mysql
查看>>
navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
查看>>
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>