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 Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指