- 累加每一行的第一个字段:
var=1000echo | awk '{print vara}' vara=$var # 输入来自stdinawk '{print vara}' vara=$var file # 输入来自文件用样式对awk处理的行进行过滤
awk 'NR < 5' #行号小于5
awk 'NR==1,NR==4 {print}' file #行号等于1和4的打印出来
awk '/linux/' #包含linux文本的行(可以用正则表达式来指定,超级强大)
awk '!/linux/' #不包含linux文本的行
设置定界符
使用-F来设置定界符(默认为空格)
awk -F: '{print $NF}' /etc/passwd
读取命令输出
使用getline,将外部shell命令的输出读入到变量cmdout中;
echo | awk '{"grep root /etc/passwd" | getline cmdout; print cmdout }' 在awk中使用循环
for(i=0;i<10;i++){print $i;}
for(i in array){print array[i];}
eg:
以逆序的形式打印行:(tac命令的实现)
seq 9| awk '{lifo[NR] = $0; lno=NR} END{ for(;lno>-1;lno--){print lifo[lno];}} 'awk实现head、tail命令
- head:
- tail:
- awk方式实现:
- cut方式实现
- 确定行号
- 确定文本
- 打印处于start_pattern 和end_pattern之间的文本;
- eg:
index(string,search_string):返回search_string在string中出现的位置
sub(regex,replacement_str,string):将正则匹配到的第一处内容替换为replacement_str;
match(regex,string):检查正则表达式是否能够匹配字符串;
length(string):返回字符串长度
echo | awk '{"grep root /etc/passwd" | getline cmdout; print length(cmdout) }' printf 类似C语言中的printf,对输出进行格式化
eg:
seq 10 | awk '{printf "->%4sn", $1}'迭代文件中的行、单词和字符
1. 迭代文件中的每一行
- while 循环法
- awk法:
- cat file.txt| awk '{print}'
for word in $line;do echo $word;done3. 迭代每一个字符
${string:start_pos:num_of_chars}:从字符串中提取一个字符;(bash文本切片)
${#word}:返回变量word的长度
for((i=0;i<${#word};i++))doecho ${word:i:1);done本文为《linux Shell脚本攻略》的读书笔记,文中主要内容和示例来自于
《linux Shell脚本攻略》
【Linux文本处理工具】
推荐阅读
- 淘宝直播对店铺的影响 淘宝直播的一般违规如何处理
- 高考撕别人答题卡处理结果 高考被撕答题卡的两名同学情况
- 淘宝上卖仿冒品的违法吗 淘宝商家售卖假冒伪劣商品会怎样处理?
- 如何告第三者破坏家庭,律师教你怎么处理小三
- 一个塑料袋怎么处理更环保 塑料袋怎么处理最环保
- 广东狗绳绊倒老人处理结果 关于狗绳绊倒老人的事件论文
- linux的那些常见目录
- 关闭windows端口的批处理命令
- 淘宝直播平台管理规则违规处理一览表 淘宝直播严重违规不扣分
- 淘宝直播录播总是被检测到违规 淘宝直播的一般违规如何处理
