liunx运维实战-----3 shell变量的核心基础知识和实践

  • 1定义环境变量并赋值的方法

    1 export 变量名=值

    2 source /etc/profile

    3 echo $变量名

    4 env | grep 变量名

  • 2 环境变量也叫全局变量

  • 3特殊情况:sed和grep没有问题

    因为 awk取用shell变量时 和之前的定义是相反的

    在awk取用shell变量时 我们更好的是先用echo加符号输出变量 然后通过管道给awk

参考代码

root@localhost data\]# echo $ETT oldgirl \[root@localhost data\]# awk 'BEGIN {print $ETT}' 输出为空格 \[root@localhost data\]# awk 'BEGIN {print '$ETT'}' 输出为空格 \[root@localhost data\]# awk 'BEGIN {print "$ETT"}' 输出为本身 KaTeX parse error: Expected 'EOF', got '#' at position 26: ...localhost data\]#̲ awk 'BEGIN {pr...ETT'"}' 输出命令的值 oldgirl \[root@localhost data\]# awk 'BEGIN {print '"$ETT"'}' 输出为空格 * 4 关于自定义普通字符串变量的建议 不带引号: 内容纯数字 简单的连续字符(不带空格) 双引号(弱引用):没有特殊情况,特别是带空格的 单引号(强引用):当变量里的内容需要原样输出时 * 5变量名及变量内容小结 1变量名只能为数字 字母 下划线,只能以字母或下划线开头 2变量名的定义要有一定的规范 并且要见名知意 * 6 shell 定义变量时使用"=" 的知识 "a=1"里等号是赋值的意思 比较变量是否相等 也可以用 "="或 "=="" * 7 补充:Awk 的两个特殊模式 BEGIN 和 END,BEGIN 被放置在没有读取任何数据之前,而 END 被放置在所有的数据读取完成以后执行 体现如下: BEGIN{}: 读入第一行文本之前执行的语句,一般用来初始化操作 {}: 逐行处理 END{}: 处理完最后以行文本后执行,一般用来处理输出结果 \[root@localhost data\]# awk -F : 'BEGIN{i=0}{if($3\<1000){i++}}END{print i}' /etc/passwd 19

相关推荐
IT逆夜4 分钟前
实现Yum本地仓库自动同步的完整方案(CentOS 7)
linux·运维·windows
a***592613 分钟前
用nginx正向代理https网站
运维·nginx·https
S***267517 分钟前
linux上redis升级
linux·运维·redis
赖small强35 分钟前
【Linux 网络基础】Linux 平台 DHCP 运作原理与握手过程详解
linux·网络·dhcp
ifanatic1 小时前
[每周一更]-(第161期):分析服务器中内存即将爆满过程
运维·服务器
热爱学习的小怪兽1 小时前
docker的一些常用指令
运维·docker·容器
s***4532 小时前
Linux 下安装 Golang环境
linux·运维·golang
JobDocLS2 小时前
Ubuntu22.04的安装方法
运维
丸子哥哥3 小时前
同一个域名,如何添加多个网站?
服务器·前端·nginx·微服务
豆豆的java之旅3 小时前
深入浅出Activity工作流:从理论到实践,让业务流转自动化
java·运维·自动化·activity·工作流