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

相关推荐
没bug怎么跑7 分钟前
rsync全网备份全流程
linux·运维·github
non-action_pilgrim9 分钟前
《小坦克大战小怪兽》小游戏实战四:基于 protoactor-go 的游戏服务器框架与状态持久化实战
服务器·游戏·golang
TechMasterPlus15 分钟前
Linux 驱动开发深度解析:从内核模块到设备驱动
linux·运维·驱动开发
念恒1230618 分钟前
Linux权限
linux·c语言
TechMasterPlus19 分钟前
浏览器自动化工具深度对比:Playwright、Chrome DevTools 与 Agent Browser
运维·自动化·chrome devtools
落羽的落羽19 分钟前
【算法札记】练习 | Week1
linux·服务器·c++·人工智能·python·算法·机器学习
炸炸鱼.21 分钟前
LVS 负载均衡群集实战指南
运维·负载均衡·lvs
王琦031823 分钟前
第十章 管理Linux的联网
linux·服务器·php
Run_Teenage27 分钟前
Linux:进程间通信-System V 共享内存
linux·运维·服务器
木子欢儿30 分钟前
Ubuntu 24.04 执行超微服务器 JNLP 程序
linux·运维·服务器·ubuntu