手把手教你在linux下熟悉使用awk的指令结构 (15)

大家好,今天和大家说一下awk吧。反正正则 早晚也要和大家说,不如一点一点和大家先交代清楚了,省得以后和大家说的时候,大家有懵的感觉。。。

其实正则里分为基础正则,和扩展正则。基础正则一般的命令就是grep和sed。而awk和egrep不止可以在基础正则内使用,还可以在扩展正则内使用。之前咱们见过sed了,其实grep和sed差不多,只是基本的语法有出入。而今天和大家说的awk,其实使用方法和egrep也差不多。

好吧。还是照例先开始今天的理论方面的东西吧。

awk 指令结构格式

1、确保整个awk命令用单引号括起来

2、确保命令内所有引号成对出现

3、确保用花括号括起动作语句,用圆括号括起条件语句

4、确保动作语句打印的字符串及转义字符用双引号引起来。

awk条件操作符

awk条件逻辑操作符

awk内置变量

awk中使用操作符,基本表达式可以划分为数字型,字符串型,变量型,域,数组元素

赋值操作符 = += *= /- %= ^=

条件表达操作符 ?

并、与、非 || && !

匹配操作符 ~ !~

关系操作符 < <= == != >>

算术操作符 + - * / % ^

前缀和后缀 ++ --------------------------------------------------------------------------------------------------------

awk的常用内置字符串函数

E.G

原例文:

[root@localhost ~]# cat wow
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

1)将整篇wow中的4全局替换成999

[root@localhost ~]# awk 'gsub(/4/,999)' wow
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

或者

[root@localhost ~]# awk 'gsub(/4/,999,$0)' wow //默认就是$0,可以不加
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

2)将用户名为M.Tansley所在行所有4替换成999

[root@localhost ~]# awk '{if($1=="M.Tansley") gsub(/4/,999); print $0}' wow
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

3)将用户名为M.Tansley所在行第三列的所有4替换成999

[root@localhost ~]# awk '{if($1=="M.Tansley") gsub(/4/,999,$3); print $0}' wow
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

4)将用户名为M.Tansley所在行第三列的所有4替换成999,并且仅显示替换行

[root@localhost ~]# awk '{if($1=="M.Tansley") {gsub(/4/,999,$3); print $0}}' wow
M.Tansley / Green

5)将用户名为M.Tansley所在行第一个出现的4替换成999,

[root@localhost ~]# awk '{if($1=="M.Tansley") sub(/4/,999); print $0}' wow
M.Tansley / Green
J.Lulu / green
P.Bunny / Yellow
J.Troll / Brown-
L.Tansley / Brown-

5)将用户名为M.Tansley所在行第一个出现的4替换成999 , 并且仅显示替换行

[root@localhost ~]# awk '{if($1=="M.Tansley") {sub(/4/,999); print $0}}' wow
M.Tansley / Green

6)查询字符串Bunny中ny是第几个出现的字符。

[root@localhost ~]# awk 'BEGIN {print index("Bunny","ny")}' grade.txt

7)查询字符串J.Troll的字符长度是多少?

[root@localhost ~]# awk '$1=="J.Troll" {print length($1),$1}' grade.txt
J.Troll

8)分别测试字符串&ldquo;ANCD&rdquo;中是否包含字符 d 或 C 或 D,如果没包含返回字符0,如果包含返回时第几个出现

字符。

[root@localhost ~]# awk 'BEGIN {print match("ANCD",/d/)}'

[root@localhost ~]# awk 'BEGIN {print match("ANCD",/C/)}'

[root@localhost ~]# awk 'BEGIN {print match("ANCD",/D/)}'

9)显示字符串L.Tansley中从第1个字符(包含)开始的后面共5个字符

[root@localhost ~]# awk '$1=="L.Tansley" {print substr($1,1,5)}' grade.txt
L.Tan

显示字符串L.Tansley中从第2个字符(包含)开始的后面共3个字符

[root@localhost ~]# awk '$1=="L.Tansley" {print substr($1,2,3)}' grade.txt
.Ta

10)用printf格式化awk的输出

[root@localhost ~]# awk 'BEGIN{printf
"%-60s","-------------------------------------------------------------"}{printf
"%-15s %s %-15s %s %s",$,"|",$,"|",$}' grade.txt
M.Tansley | |
J.Lulu | |
P.Bunny | |
J.Troll | |
L.Tansley | | [root@localhost ~]# awk 'BEGIN{printf "%-39s","----------------------------------------";printf
"%-15s %s %-15s %s %-1s %s","name","|","student_id","|","age","|";printf
"%-52s","----------------------------------------"}{printf
"%-15s %s %-15s %s %-3s %s",$,"|",$,"|",$,"|"}END{printf
"%-39s","----------------------------------------"}' grade.txt
name | student_id | age |
---------------------------------------- M.Tansley | | |
J.Lulu | | |
P.Bunny | | |
J.Troll | | |
L.Tansley | | |
----------------------------------------------------------------------------------------------------------------------------

今天的课程,就讲解到这里吧。

实在是不知道要写什么了,周末下午回北京,这车堵的。。。实在是累坏了。晚上又帮一个粉丝一个散件一个散件的攒机器。终于是又给他省了一笔钱啊。。。写完了才发现,昨天你们都没给我评论今天具体要写什么。。。我这还是突然想到之前只写了sed,今天打算把awk写完,才写的这个。。。

你们的基础如果都没问题的话,那我明天不写基础的东西了。。。实在是不知道大家需要什么东西啊,是不是都感觉随便搭建一个服务很有学习效果?那样学习的更有感觉???那为什么看vi/vim的和YUM的,也很多啊。。。苦恼中。。

awk的常用内置函数的使用【转】的更多相关文章

  1. MYSQL常用内置函数详解说明

    函数中可以将字段名当作变量来用,变量的值就是该列对应的所有值:在整理98在线字典数据时(http://zidian.98zw.com/),有这要一个需求,想从多音字duoyinzi字段值提取第一个拼音 ...

  2. Python常用模块中常用内置函数的具体介绍

    Python作为计算机语言中常用的语言,它具有十分强大的功能,但是你知道Python常用模块I的内置模块中常用内置函数都包括哪些具体的函数吗?以下的文章就是对Python常用模块I的内置模块的常用内置 ...

  3. MySQL学习笔记_7_MySQL常用内置函数

    MySQL常用内置函数 说明: 1)可以用在SELECT/UPDATE/DELETE中,及where,orderby,having中 2)在函数里将字段名作为参数,变量的值就是字段所对应的每一行的值. ...

  4. PYTHON语言之常用内置函数

    一 写在开头本文列举了一些常用的python内置函数.完整详细的python内置函数列表请参见python文档的Built-in Functions章节. 二 python常用内置函数请注意,有关内置 ...

  5. SqlServer常用内置函数

    --======================================= -- SQL常用内置函数 --======================================= --判 ...

  6. Python的常用内置函数介绍

    Python的常用内置函数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.取绝对值(abs) #!/usr/bin/env python #_*_coding:utf-8_ ...

  7. python中的运算符及表达式及常用内置函数

    知识内容: 1.运算符与表达式 2.for\while初步了解 3.常用内置函数 一.运算符与表达式 python与其他语言一样支持大多数算数运算符.关系运算符.逻辑运算符以及位运算符,并且有和大多数 ...

  8. python第十八课——常用内置函数

    常用内置函数:round(): print(round(3.14),round(3.99)) print(round(3145.926,-2),round(413.575,2)) abs(): pri ...

  9. php2go - Go 实现 PHP 常用内置函数

    [转]http://www.syyong.com/Go/php2go-Use-Golang-to-implement-PHP-s-common-built-in-functions.html 使用Go ...

随机推荐

  1. BZOJ3444 最后的晚餐(并查集)

    容易发现只要图中有非链部分则无解.剩下就非常简单了. #include<iostream> #include<cstdio> #include<cmath> #in ...

  2. http站点如何启用为https站点?对收录的影响

    首先看一下百度官方对https站点的态度:百度开放收录https站点公告 百度搜索再次推出:全面支持https页面直接收录:另外从相关性的角度,百度搜索引擎认为权值相同的站点,采用https协议的页面 ...

  3. AptanaStudio3+PHP程序远程调试的方法和步骤

    php是执行在服务器上的脚本程序,通常调试bug,直接在浏览器页面就可以打印出错误信息,凭此基本能解决所有bug,但是有时候,可以说大多数时候,php会直接处理客户端的请求,作为数据接口传递数据,没有 ...

  4. 【JQuery】Ajax

    一.前言        接着上一章的内容,继续本章的学习.本章知识来自于https://www.cnblogs.com/jach/p/5709175.html 二.内容 $.ajax({ url:'/ ...

  5. IDEA的强大

    由于朋友推荐,转战IDEA数日,发现一个字就是,牛,完爆任何开发工具,让你代码上瘾的工具. 它集合了所有的开发所需要的东西,且智能化方便,适合开发有一定经验的人去使用,你会爱上它. 下面是快捷键的使用 ...

  6. 为smokeping添加日志开启debug

    用包管理工具安装smokeping没有自带日志输出,为了定位问题开启日志就成为第一需求. 1.修改smokeping的配置 # vim /etc/smokeping/config.d/General ...

  7. GridView中网络图片延迟加载导致高度计算失败的问题

    在使用下拉刷新以及加载更多控件的时候,出现了列表上滚不完的现象,经过半天的分析,最后得出结论:由于图片采用了延迟加载,导致列表按照没有加载图片时候的大小进行布局,相关的加载更多控件也就傻逼了. 最终解 ...

  8. bug2 The method of type must override a superclass method解决方式(去掉@override可以)

    @Override 时出错误: 解决办法是: 一.                                                                     因为你的Co ...

  9. 使用EntitysCodeGenerate

    http://bbs.csdn.net/topics/360256700 public DataSet xxx(DateTime start, DateTime end, string type)   ...

  10. Go_19: Golang 中错误与异常需要重新认识

    如何进行错误处理,这是一个Go程序员之间,特别是一些新的Go程序员,会经常讨论的问题.讨论到最后往往由于以下代码的多次出现而变成了抱怨. if err != nil { return err } 我们 ...