Day19-三剑客之awk实践

2024-02-27 19:20
文章标签 实践 day19 awk 三剑客

本文主要是介绍Day19-三剑客之awk实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Day19-三剑客之awk实践

练习:/etc/passwd,/etc/fstab
首先准备好测试文件,取passwd文件前5行。

sed -n '1,5p' /etc/passwd >test.txt
[root@oldboy ~]# sed -n '1,5p' /etc/passwd >test.txt
[root@oldboy ~]# cat test.txt 
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

问题1:取test.txt文件的第2行到第3行的内容。
方法1:

[root@oldboy ~]# sed -n '2,3p' test.txt 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

方法2:

[root@oldboy ~]# awk 'NR==2,NR==3' test.txt 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin打印2-3行,同时打印行号
[root@oldboy ~]# awk 'NR==2,NR==3{print NR,$0}' test.txt 
2 bin:x:1:1:bin:/bin:/sbin/nologin
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

方法3:

[root@oldboy ~]# awk 'NR>1&&NR<4' test.txt 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

方法4:

[root@oldboy ~]# head -3 test.txt |tail -2
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin

方法5:

[root@oldboy ~]# grep -A 1 -n "^bin" test.txt 
2:bin:x:1:1:bin:/bin:/sbin/nologin
3-daemon:x:2:2:daemon:/sbin:/sbin/nologin[root@oldboy ~]# grep -B 1 -n "^dae" test.txt 
2-bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
!    取反
&& (并且)
|| (或者)
== (表示相等)
=    赋值 a=1  

专业取行 sed

专业取列 awk

专业过滤 grep

问题2:过滤出含有root字符串的行※。

[root@oldboy ~]# awk '/root/' test.txt 
root:x:0:0:root:/root:/bin/bash[root@oldboy ~]# grep root test.txt 
root:x:0:0:root:/root:/bin/bash[root@oldboy ~]# sed -n '/root/p' test.txt 
root:x:0:0:root:/root:/bin/bash

问题3:删除含有root字符串的行※。

[root@oldboy ~]# sed '/root/d' test.txt 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin[root@oldboy ~]# awk '/^[^r]/' test.txt 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

问题4:取文件的第一列、第三列和最后一列内容,并打印行号※。

[root@oldboy ~]# awk -F ":" '{print NR,$1,$3,$NF}' test.txt 
1 root 0 /bin/bash
2 bin 1 /sbin/nologin
3 daemon 2 /sbin/nologin
4 adm 3 /sbin/nologin
5 lp 4 /sbin/nologin

问题5:取出Linux中执行ifconfig eth0后对应的IP地址(只能输出IP地址)。

[root@oldboy ~]# ifconfig eth0|sed -rn 's#^.*inet (.*)  netm.*$#\1#gp'
10.0.0.130[root@oldboy ~]# hostname -I
10.0.0.130 10.0.0.129[root@oldboy ~]# ifconfig eth0|awk 'NR==2{print $2}'
10.0.0.130

把要取的内容两边相邻的一堆内容做分隔符。

[root@oldboy ~]# ifconfig eth0|awk -F "(inet )|(  netm)" 'NR==2{print $2}' 
10.0.0.130
#<==竖线正则的意思表示匹配或者左边或者右边,小括号是分组作为一个整体,即以“addr:”或“  Bcast:”做分隔符

多分隔符用法:

[root@oldboy ~]# echo "1::::2====3----4"|awk -F "[:=-]+" '{print $1,$2,$3,$4}'
1 2 3 4
[:=-]  #里面任意一个做分隔符
[:=-]+ #遇到[]里的任意多个字符算一个。#上述不同的分隔符连续也算一个。
[root@oldboy ~]# echo "1:::==:2==::==3----4"|awk -F "[:=-]+" '{print $1,$2,$3,$4}'
1 2 3 4

练习:

用awk取stat /etc/hosts结果的644

解答:先取行,在取列。

[root@oldboy ~]# stat /etc/hosts|awk 'NR==4'
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
[root@oldboy ~]# stat /etc/hosts|awk -F "[0/]" 'NR==4{print $2}'
644

带条件的AWK;

【行的条件】

[root@oldboy ~]# stat /etc/hosts|awk -F "[0/]" 'NR==4{print $2}'
644

【内容模糊匹配】

问题6:过滤文件中第一列内容匹配root的字符串,把符合的行的最后一列输出。

解答:这道题在过滤日志信息的时候常用,示例如下。

[root@oldboy ~]#  awk -F ":" '$1~/root/ {print $NF}' test.txt 
#<==$1~/root/表示第一列内容匹配root条件,$NF表示最后一列。#/etc/passwd
awk -F ":"  '$1~/oldboy/{print $NF}' /etc/passwd

问题7:过滤下列test1.txt文件中第三列内容分数大于70,并且小于95的人名和性别。

[root@oldboyedu ~]# cat test1.txt 
张三 男  80
李四 女  70
王五 男  90
赵六 女  100

中文乱码:

1)调解xshell属性-终端-字符集-简体中文gb18030(只调一个就好了)

2)如果还不行做如下调整:

[root@oldboy ~]# tail -2 /etc/profile
#export LANG='en_US.UTF-8'
export LANG='zh_CN.UTF-8'# 生效:
. /etc/profile

解答:

[root@oldboy ~]# awk '$3>70&&$3<95{print $1,$2}' test1.txt  
张三 男
王五 男

把要取的内容两边相邻的一堆内容做分隔符。

[root@oldboy ~]# ifconfig eth0|awk -F "(inet )|(  netm)" 'NR==2{print $2}' 
10.0.0.130
#<==竖线正则的意思表示匹配或者左边或者右边,小括号是分组作为一个整体,即以“addr:”或“  Bcast:”做分隔符

【答案】
https://ke.qq.com/course/2806831?taid=9996020988171311

这篇关于Day19-三剑客之awk实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/753351

相关文章

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更