第九周作业

awk基础

简介

       AWK是一种优良的文本处理工具。它是 Linux 中也是任何环境中现有的功能最强大
的数据处理引擎之一,相比sed常常作用于一整行的处理,awk比较倾向于将一行分成数
个“字段”来处理。所以,awk相当适合处理小型的数据处理。

基础用法

awk[选项] ‘program’ var=value file…
awk[选项] -f programfilevar=value file…
awk[选项] 'BEGIN{ 动作;… } pattern{ 动作;… } END{ 动作;… }' file ...
  • awk程序通常由:BEGIN语句块、能够使用模式匹配的通用语句块、END语句块,共3部分组成

  • program通常是被单引号或双引号中

示例

  • awk主要是处理每一行的字段内的数据,而默认的字段的分隔符为空格键或[TAB]键。举例说明,我们用cat /etc/passwd这个可以查看用户:

第九周作业

  • 若我想取出用户名称和shell类型,且名称与shell类型以冒号隔开,则成这样:
awk  -F: '{print $+1":"$7} ' /etc/passwd

第九周作业

  • 这是awk最常用的动作,通过print的功能将字段数据列出来,字段的分割可以自己选择 以什么方式隔开,-F指定域分隔符为’:’。

系统变量

  • OFS                   输出字段分隔符,默认为空白字符
  • FS                      输入字段分隔符,默认为空白字符
  • ORS                   输出记录分隔符,输出时用指定符号代替换行符
  • RS                      输入记录分隔符,指定输入时的换行符,原换行符仍有效
  • NF                      每一行的字段数量
  • NR                      行数
  • FNR                    各个文件分别计数,行数
  • ARGC                  命令行的参数个数
  • ARGV                  数组,保存的是命令行所给定的各参数
  • FILENAME        当前文件名

此外,$0变量是指整条记录,$1表示当前行的第一个域,$2表示当前行的第二个域,……以此类推。


自定义变量(区分字符大小写)

  • -v var=value

  • 在program中直接定义

两种方法:

VAR=10000;echo | awk -v VARIABLE=$VAR '{ print VARIABLE }'
var1="aaa";var2="bbb";echo | awk '{ print v1,v2 }' v1=$var1 v2=$var2

选项参数

  • -F

指明输入时用到的字段分隔符

  • -v var=value

自定义变量。


要点

  1. 逗号分隔符
  2. 输出的各item可以字符串,也可以是数值;当前记录的字段、变量或awk的表达式
  3. 如省略item,相当于print $0

printf命令

格式化输出:

printf“FORMAT”, item1, item2, ...

  1. 必须指定FORMAT
  2. 不会自动换行,需要显式给出换行控制符,
  3. FORMAT中需要分别为后面每个item指定格式符

格式符

  • %c      显示字符的ASCII码
  • %d      显示十进制整数
  • %i       显示十进制整数
  • %e      显示科学计数法数值
  • %E      显示科学计数法数值
  • %f       显示为浮点数
  • %g       以科学计数法或浮点形式显示数值
  • %G      以科学计数法或浮点形式显示数值
  • %s       显示字符串
  • %u      无符号整数
  • %%     显示%自身

awk -F: '{printf"%s",$1}' /etc/passwd

第九周作业

修饰符

  1. /#[.#]:第一个数字控制显示的宽度;第二个#表示小数点后精度,%3.1f
  2. -: 左对齐(默认右对齐)%-15s
  3. +:显示数值的正负符号%+d

awk -F: '{printf "%-20s %10d\n",$1,$3}' /etc/passwd

第九周作业

awk -F: '{printf "Username:%-15s,UID:%d\n",$1,$3}' /etc/passwd

第九周作业


原创文章,作者:Az2h1丶,如若转载,请注明出处:http://www.178linux.com/81522

(0)
Az2h1丶Az2h1丶
上一篇 2017-07-16
下一篇 2017-07-16

相关推荐

  • MySQL主从复制: MHA

                    MySQL主从复制: MHA 前言 MHA的架构 环境部署 实验步骤 总结 前言 上篇文章我们实现了MySQL的主从复制, 但是我们之前就说过, 主从复制是有很多问题的…

    Linux干货 2016-04-28
  • 关于VIM编辑器

                                                      &nbsp…

    系统运维 2016-08-11
  • 日志收集工具EFK之fluent部署手稿

    Edit EFK fluent部署安装 1. 环境介绍 Centos 6.5 64bit 2. 安装 td-agent介绍 fluent 考虑到灵活可扩展性,使用Ruby编写,部分功能考虑性能使用C语言编写。普通用户安装操作Ruby daemon还是有一定难度的。考虑到flunt的上手难度, fluent专门发布了稳定发布包,就也是所谓的td-agent. …

    Linux干货 2016-03-24
  • 文本三剑客之sed

      文本处理三剑客:    grep,egrep,fgrep:文本过滤器    sed:stream  editor,流编辑器,是一行一行处理的    awk :文本格式化工具,报告生成器     sed工作方式:它是读一行的文本…

    Linux干货 2016-08-15
  • N22 网络班-第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。   2、取出最后登录到当前系统的用户的相关信息。   3、取出当前系统上被用户当作其默认shell的最多的那个shell。   4、将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxus…

    Linux干货 2016-09-06
  • lvs笔记之nat&dr模型简单实现

    lvs笔记之nat&dr模型简单实现 lvs笔记之nat&dr模型简单实现 lvs 集群 实现 负载均衡 nat lvs笔记之nat&dr模型简单实现 ipvsadm使用说明 lvs-nat的简单实现 踩过的坑1 lvs-dr实现 总结 ipvsadm使用说明     -A: 添加一个…

    2017-01-03