文本三剑客正则表达式3

news/2024/11/19 15:23:13/

文章目录

  • 文本三剑客&正则表达式3
    • 1 awk工作原理
    • 2 awk的基本格式及其内置变量
      • 2.1 基本格式
      • 2.2 内置变量
      • 2.3 示例
        • 2.3.1 直接打印所有内容
        • 2.3.2 取每一行的第一列
        • 2.3.3 打印行号,及所有内容
        • 2.3.4 打印第三行
        • 2.3.5 打印2-4行
        • 2.3.6 打印第2行和第4行
        • 2.3.7 用正则表达式打印2-4行
        • 2.3.8 打印偶数行
        • 2.3.9 打印奇数行
    • 3 awk的运算
      • 3.1 算100+200的和
      • 3.2 求3的2次方
    • 4 getline
      • 4.1 getline的工作过程
      • 4.2 示例
        • 4.2.1 打印偶数行
        • 4.2.2 打印奇数行
        • 4.2.3 把test1的内容传给函数getline,getline获取后把他打印出来并传给test
        • 4.2.4 把ls的结果传给函数getline后,赋值给变量line,并把line的值打印出来
    • 5 文本内容匹配过滤打印
      • 5.1 打印出以root开头的
      • 5.2 打印出以bash结尾的
    • 6 BEIGIN模式指定BEGIN打印模式
      • 6.1 处理过程
    • 7 对字段进行处理打印
      • 7.1 以:为分隔符,打印第一列
      • 7.2 -v的用法:变量赋值
        • 7.2.1 将输入的时候的分隔符:改成+输出,打印第一列和第三列
        • 7.2.2 以:为分隔符,换行输出
      • 7.3 BEIGIN模式指定打印内容
      • 7.4 条件判断打印
        • 7.4.1 如果第三列uid大于500,打印出来
        • 7.4.2 如果第三列uid不大于500,打印出来
    • 8 awk的三元表达式与精准筛选用法
      • 8.1 输出第七个字段包含“bash”所在行的第一个字段和最后一个字段
      • 8.2 输出第七个字段不包含“nologin”所在行的第一个字段和最后一个字段
      • 8.3 输出第六个字段为/home/qiao,第七个字段为/bin/bash的这些行的第一列和最后一列
      • 8.4 指定输出的分隔符
    • 9 数组
      • 9.1 定义数组打印
      • 9.2 awk中的数组形成遍历,在awk中打印变量不需要加$
      • 9.3 数组去重
      • 9.4 索引号是文本里面的内容,对索引号进行计数

文本三剑客&正则表达式3

1 awk工作原理

  • sed命令常用于一整行的处理

    • 而awk比较**倾向于将一行分成多个“字段”**然后再进行处理
      • 且默认情况下字段的分隔符为空格或 tab 键
  • awk 执行结果可以通过 print 的功能将字段数据打印显示

2 awk的基本格式及其内置变量

2.1 基本格式

awk 选项 '模式或条件 {操作}' 文件1 文件2...
  • F “分隔符”

    • 指明输入时用到的字段分隔符,默认的分隔符是若干个连续空白符
  • v(小v) var=value 变量赋值

注意一定是单引号

‘模式或条件 {操作}’

{ }外指定条件,{ }内指定操作

逗号指定连续的行、用 || 指定不连续的行、**&&**表示”且“


2.2 内置变量

内建变量,不能用双引号括起来,不然系统会把它当成字符串

内置变量意义
$0当前处理的行的整行内容
$n当前处理行的第n个字段(第n列)
NR当前处理的行的行号(序数)
NF当前处理的行的字段个数,##$NF代表最后一个字段
FS指定每行文本的字段分隔符,输入内容的分隔符 默认为空格或制表位。与"-F"作用相同 用-F可以不加单引号 -F:,用FS必须用=“”
OFS输出内容的列分隔符
FILENAME被处理的文件名
RS行分隔符

2.3 示例

2.3.1 直接打印所有内容

在这里插入图片描述
在这里插入图片描述

2.3.2 取每一行的第一列

在这里插入图片描述

2.3.3 打印行号,及所有内容

在这里插入图片描述

2.3.4 打印第三行

在这里插入图片描述

2.3.5 打印2-4行

在这里插入图片描述

2.3.6 打印第2行和第4行

在这里插入图片描述

2.3.7 用正则表达式打印2-4行

在这里插入图片描述

2.3.8 打印偶数行

在这里插入图片描述

2.3.9 打印奇数行

在这里插入图片描述

3 awk的运算

可以进行小数和整数的运算

还能进行幂的计算

3.1 算100+200的和

在这里插入图片描述

3.2 求3的2次方

在这里插入图片描述


4 getline

4.1 getline的工作过程

  • 当getline左右**无重定向符号(“<”)或者管道符号(“|”)**时

    • awk首先读取的是第一行,
    • 而getline获取的是光标跳转至下一行的内容(也就是第二行)
  • 当getline左右有管道符号或重定向符

    • getline则作用定向输入文件,由于文件是刚打开,并没有被awk读入一行,而只是getline读入,所以getline返回的是文件的第一行,而不是跳转至一行输入

原因:getline运行之后awk会改变NF,NR,$0,FNR等内部变量,所以此时读取$0的行号不再为1,而是2

4.2 示例

4.2.1 打印偶数行

在这里插入图片描述

4.2.2 打印奇数行

在这里插入图片描述

4.2.3 把test1的内容传给函数getline,getline获取后把他打印出来并传给test

在这里插入图片描述

4.2.4 把ls的结果传给函数getline后,赋值给变量line,并把line的值打印出来

在这里插入图片描述


5 文本内容匹配过滤打印

5.1 打印出以root开头的

在这里插入图片描述

5.2 打印出以bash结尾的

在这里插入图片描述


6 BEIGIN模式指定BEGIN打印模式

格式:awk 'BEGIN{...};{...};END{...}' 文件

6.1 处理过程

  1. 在awk处理指定的文本之前,需要先执行BEGIN{…}模式里的命令操作

  2. 中间的**{…} 是真正用于处理文件的命令操作**

  3. 在awk处理完文件后才会执行END{…}模式里的命令操作。END{ }语句块中,往往会放入打印结果等语句。

x的变量范围是根据文本中内容的行数来的

在这里插入图片描述

7 对字段进行处理打印

7.1 以:为分隔符,打印第一列

7.2 -v的用法:变量赋值

7.2.1 将输入的时候的分隔符:改成+输出,打印第一列和第三列

在这里插入图片描述

7.2.2 以:为分隔符,换行输出

#默认就是换行输出,不需要改

在这里插入图片描述

7.3 BEIGIN模式指定打印内容

以:为分隔符打印第一列

在这里插入图片描述

7.4 条件判断打印

7.4.1 如果第三列uid大于500,打印出来

在这里插入图片描述

7.4.2 如果第三列uid不大于500,打印出来

在这里插入图片描述


8 awk的三元表达式与精准筛选用法

awk的三元表达式继承了java的用法,格式与Java相似

格式:awk '(条件表达式)?(A表达式或者值):(B表达式或者值)'

以:为分隔符,如果$3大于$4,则打印$3,否则打印$4
在这里插入图片描述

awk的精准筛选

$n(> < ==): 用于对比数值$n~"字符串": 代表第n个字段包含某个字符串$n!~"字符串": 代表第n个字段不包含某个字符串$n=="字符串": 代表第n个字段为某个字符串$n!="字符串": 代表第n个字段不为某个字符串$NF: 代表最后一个字段

8.1 输出第七个字段包含“bash”所在行的第一个字段和最后一个字段

在这里插入图片描述

8.2 输出第七个字段不包含“nologin”所在行的第一个字段和最后一个字段

在这里插入图片描述

8.3 输出第六个字段为/home/qiao,第七个字段为/bin/bash的这些行的第一列和最后一列

在这里插入图片描述

8.4 指定输出的分隔符

  • OFS:输出内容的列分隔符( n = n= n=n用于激活,否则不生效,n必须存在)

  • 对于输出时改变分隔符,我们常用到tr,awk,它们都可以实现在输出内容改变原本的分隔符
    在这里插入图片描述
    在这里插入图片描述

9 数组

9.1 定义数组打印

在这里插入图片描述

9.2 awk中的数组形成遍历,在awk中打印变量不需要加$

在这里插入图片描述

9.3 数组去重

  1. 索引号可以是数字,字符

  2. 统计索引号出现的次数

  3. 遍历行数

9.4 索引号是文本里面的内容,对索引号进行计数

在这里插入图片描述


http://www.ppmy.cn/news/75774.html

相关文章

最近最少使用(LRU, Least recently used)缓存算法_华为2023

思路 性能限制很高、数据量很大时&#xff0c;cin、cout肯定是不够快的。 &#xff08;1&#xff09;可以利用getchar()速度快的特性设计快读函数读取整数&#xff0c;可以做到用scanf()函数5倍的速度读入任意整数&#xff1a; #include<cstdio> // 仅正整数可用 #defi…

多线程基础(一)线程基础信息、synchronized 锁概念

1. 基本概念&#xff1a; 程序&#xff1a; 程序是一些保存在磁盘上的指令的有序集合&#xff0c;是静态的。程序包括&#xff1a;内存资源、IO资源、信号处理等。&#xff08;如&#xff1a;XX.exe&#xff09; 进程&#xff1a; 进程是程序执行的过程&#xff0c;包括了动态…

XPCIE1032 — 高速高精,超快交互速率的PCIe EtherCAT实时运动控制卡

产品导读 XPCIE1032是一款基于PCI Express的EtherCAT总线运动控制卡&#xff0c;可选4-16轴运动控制&#xff0c;支持多路高速数字输入输出&#xff0c;可轻松实现多轴同步控制和高速数据传输。 XPCIE1032集成了强大的运动控制功能&#xff0c;结合MotionRT7运动控制实时软核…

redis 数据库概述

一 概述 redis是一种nosql数据库,他的数据是保存在内存中&#xff0c;同时redis可以定时把内存数据同步到磁盘&#xff0c;即可以将数据持久化&#xff0c;并且他比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合],hash(hash表))。相关…

SpringBoot中使用枚举类、switch、常量类(声明并初始化map)实现类策略者模式,接口返回常量数据

场景 SpringBoot中策略模式工厂模式业务实例(接口传参-枚举类查询策略映射关系-执行不同策略)规避大量if-else&#xff1a; SpringBoot中策略模式工厂模式业务实例(接口传参-枚举类查询策略映射关系-执行不同策略)规避大量if-else_霸道流氓气质的博客-CSDN博客 SpringBootVa…

learn_C_deep_12 (深度理解“取整“、“取余“、“取模“运算、掌握运算符优先级 )

目录 关于“取整” "取整"规则 1、向零取整 2、向-∞取整 3、向∞取整 4、四舍五入 关于"取模和取余" 运算符优先级 关于“取整” #include <stdio.h> int main() {//本质是向0取整int i -2.9;int j 2.9;printf("%d\n", i); /…

数据结构与算法之逻辑回归详解

逻辑回归&#xff08;Logistic Regression&#xff09;是一种广义线性模型&#xff0c;在分类问题中广泛应用&#xff0c;特别是二分类问题。逻辑回归可以通过把输入的特征与权重线性组合&#xff0c;再通过逻辑函数&#xff08;sigmoid函数&#xff09;将结果映射到0~1之间&am…

云HIS住院业务模块常见问题及解决方案

一&#xff1a;住院业务 1.患者办理住院时分配了错误的病区怎么办&#xff1f; 操作员误操作将患者分配了错误的病区分为以下两种情况&#xff1a; &#xff08;1&#xff09;、患者刚刚入院&#xff0c;未分配床位、主治医师与管床护士&#xff1a;这种情况比较好处理&#xf…