如转载请指明(博客http: yangzhigang cublog cn)。前言:有时我们需要将某个域之后的所有域打印出来,而且每个记录(行)的域的个数也不一定,所以用$4,$5,… $n,… $(NF-1),$NF穷举是不现时的,
如转载请指明“(源自: 博客 http://yangzhigang.cublog.cn)”。

 
前言:
有时我们需要将某个域之后的所有域打印出来,而且每个记录(行)的域的个数也不一定,所以用“$4,$5,…..$n,….$(NF-1),$NF”穷举是不现时的,我经过测试,总结了一下实现的方法,供大家参考。
 
一.利用输出函数printf
// 测试文件内容
[root@cacti tmp]# cat file.txt 
x1 x2 x3
x1 x2 x3 x4 x5
x1 x2 x3 x4 x5 x6
x1 x2 x3 x4 x5 x6 x7 x8
x1 x2 x3 x4 x5 x6 x7
 
[root@cacti tmp]# awk '{for(i=4;i<=NF;i++) printf"%s ",$i} {print ""}' file.txt
 
x4 x5 
x4 x5 x6 
x4 x5 x6 x7 x8 
x4 x5 x6 x7
[root@cacti tmp]# awk '{for (i=4;i<=NF;i++) {printf $i" "}printf "\n"}' file.txt
 
x4 x5 
x4 x5 x6 
x4 x5 x6 x7 x8 
x4 x5 x6 x7
 
问题:
1) 在NF不够4个的记录(行),将会打印出一个空行;
2) 在输出的结果中,每行结尾多了一个空格;
 
下面两种命令,分别对上面两个命令加了NF>4的判断,结果是一致的,解决了上面的第一个问题:“在NF不够4个的记录(行),将会打印出一个空行;”。
[root@cacti tmp]# awk '{for(i=4;i<=NF;i++) printf"%s ",$i};NF>4 {print ""}' file.txt 
x4 x5 
x4 x5 x6 
x4 x5 x6 x7 x8 
x4 x5 x6 x7
[root@cacti tmp]# awk 'NF>4 {for (i=4;i<=NF;i++) {printf $i" "}printf "\n"}' file.txt 
x4 x5 
x4 x5 x6 
x4 x5 x6 x7 x8 
x4 x5 x6 x7
 
二.利用字符串函数index和substr
// 测试文件内容
[root@cacti tmp]# cat file.txt 
x1 x2 x3
x1 x2 x3 x4 x5
x1 x2 x3 x4 x5 x6
x1 x2 x3 x4 x5 x6 x7 x8
x1 x2 x3 x4 x5 x6 x7
[root@cacti tmp]# cat file.txt |awk '{a=index($0,$4);print substr($0,a)}'
x1 x2 x3
x4 x5
x4 x5 x6
x4 x5 x6 x7 x8
x4 x5 x6 x7
 
可以发现,执行上面这个命令时,在NF不够4个的记录(行),将会打印出整行记录;为解决这个问题,可以像上文所采用的方法,加上“NF>4”,如下:
[root@cacti tmp]# cat file.txt |awk 'NF>4 {a=index($0,$4);print substr($0,a)}'
x4 x5
x4 x5 x6
x4 x5 x6 x7 x8
x4 x5 x6 x7
 
这种方法似乎很完美,但是分析实现原理,可以发现,本方法是通过分析出$4这个字段的字串在$0(整个记录)中第一次出现的位置,记数为a,之后再截取a之后的字串,并打印。那么,如果$4的字串在之前就出次过,则a的数值就是前面的出现的位置了,结果就会是错误的,为解决这个问题,可以将$4替换一下,再定位,测试如下:
// 测试文件内容
[root@cacti tmp]# cat filexx.txt 
x1 x2 x3
x1 x4 x3 x4 x5
x1 x4 x4 x4 x5 x6
x4 x2 x3 x4 x5 x6 x7 x8
x1 x2 x3 x4 x4 x6 x7
(本文件,可以发现$4的字串:x4,在2,3,4,5行,在$4之前的域都有出现过与之相同的字串:x4)
//下面是用上面的方法,结果显然有误的,是将以x4开始的域之后的所有域全打印出来了。
[root@cacti tmp]# cat filexx.txt |awk 'NF>4 {a=index($0,$4);print substr($0,a)}'
x4 x3 x4 x5
x4 x4 x4 x5 x6
x4 x2 x3 x4 x5 x6 x7 x8
x4 x4 x6 x7
 
//对$4重新赋值,在$4前加个“z”,以区分之前域于之相同的字串
[root@cacti tmp]# cat filexx.txt |awk 'NF>4 {$4="z"$4;a=index($0,$4);print substr($0,a)}'
zx4 x5
zx4 x5 x6
zx4 x5 x6 x7 x8
zx4 x4 x6 x7
 
//将上个命令中加的字串“z”过滤掉,得到想要的结果
[root@cacti tmp]# cat filexx.txt |awk 'NF>4 {$4="n"$4;a=index($0,$4);print substr($0,a+1)}'
x4 x5
x4 x5 x6
x4 x5 x6 x7 x8
x4 x4 x6 x7
 
//指定分隔符为一个空格,指定(多个)分隔符时,要写在方括号中,此方法对某个字段(如yang  zhi  gang为表示名字的字段)中有多个空格很有用。
[root@cacti tmp]# cat filexx.txt |awk 'BIGIN{FS="[ ]"} NF>4 {$4="n"$4;a=index($0,$4);print substr($0,a+1)}'
x4 x5
x4 x5 x6
x4 x5 x6 x7 x8
x4 x4 x6 x7
 
三.利用域值替换
    就是将某个(些)域替换成空值,如去除第一个域为:awk '{ $1=""; print $0 }' file.in
// 测试文件内容
[root@cacti tmp]# cat file.txt 
x1 x2 x3
x1 x2 x3 x4 x5
x1 x2 x3 x4 x5 x6
x1 x2 x3 x4 x5 x6 x7 x8
x1 x2 x3 x4 x5 x6 x7
 
//前3个域用字母a替换
[root@cacti tmp]# awk '{ for(i=1;i<=3;i++){$i="a"}; print $0 }' file.txt 
a a a
a a a x4 x5
a a a x4 x5 x6
a a a x4 x5 x6 x7 x8
a a a x4 x5 x6 x7
 
//前3个域用空格替换
[root@cacti tmp]# awk '{ for(i=1;i<=3;i++){$i=""}; print $0 }' file.txt 
  
   x4 x5
   x4 x5 x6
   x4 x5 x6 x7 x8
   x4 x5 x6 x7
问题:
1) 在NF不够4个的记录(行),将会打印出一个空行;
2) 在输出的结果中,去除的域会用空格来代替
 
// 去除上面命令输出的空行,但输出结果前端会有空格
[root@cacti tmp]# awk 'NF>4 { for(i=1;i<=3;i++){$i=""}; print $0 }' file.txt
   x4 x5
   x4 x5 x6
   x4 x5 x6 x7 x8
   x4 x5 x6 x7
 
总结:
   本文介绍了三种方法来解决AWK“只打印第N个域之后的所有域”的问题。
   第一和第三种方法会出现输出结果后端或前端加空格的情况,但这可能不会影响你后绪的操作,可以结合管道再处理。
   根据你的需要选择合适的方法吧。

AWK只打印某个域后的所有域的更多相关文章

  1. excel怎么只打印某页?excel怎么只打印某几页

    有时候我们需要打印的excel文件,内容较多有好几页,而我们只需要打印里面的部分内容,为了减少纸张.碳粉的浪费,我们怎样精准打印某页或某几页呢?   工具/原料   Excel / WPS软件 方法/ ...

  2. 关闭rdlc报表打印预览后,关闭客户端,抛出异常“发生了应用程序级的异常 将退出”

    问题:关闭rdlc报表打印预览后,关闭客户端,抛出异常“发生了应用程序级的异常 将退出” 办法:在容纳ReportViewer的窗体后台代码中,添加如下代码即可 protected override ...

  3. log4j配置只打印指定jar或包的DEBUG信息

    有的时候查问题的时候需要打印第三方jar里面的debug信息,假如全部jar都打印的话日志文件会很大,这个时候可以配置log4j只打印指定jar的debug信息或者包,同时输出到了一个新的文件中. 比 ...

  4. SQLServer加入域后无法远程连接

    如果您更改的SQLServer的远程连接端口(默认1433),加入域后,防火墙会把自定义规则都禁用掉 所以,你得进防火墙,查看,是否防火墙关闭了,我的就是关闭了,找了半天原因

  5. NodeJs 设置跨域后页面全部变成了源码在浏览器上显示

    百度搜索跨域后得到 app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin" ...

  6. lua 写逻辑打印log时,打印到一半后停止不再打印,程序停止

    问题描述:ubuntu下用lua开发游戏电子邮件模块,自己测试时向用户推送100封,而用户最多只能有50封.这是调用sysdelete删除一些邮件.当打印log时,打印到一半后程序中途停止.将打印lo ...

  7. .NET Framework 3.5 无法安装以下功能 安装错误:0x800F0906(客户端加域后出现)

    问题:安装错误:0x800F0906    系统安装并加域后,在安装用友软件时提示没有.net 3.5 系统为win10 但是,点击确定后,却出现了这样的错误.如下: 点击下载并安装此功能,出现了这样 ...

  8. excel中如何设置只打印第一页

    在打印表格时,怎样设置只打印第一页呢,操作很简单,下面,小编说下操作方法.   方法/步骤     打开要打印的工作表, 再点击“文件”   弹出的页面中,在左侧这里,点击“打印”   在右边弹出与打 ...

  9. nginx处理vue打包文件后的跨域问题

    起因 在vue文件打包后,项目脱离了vue配置的反向代理配置,还是会报跨域的错误,或者直接打不开本地文件, 但是此刻我们想打开打包后的文件,测试一下文件有没有错误,因为经常会存在开发阶段没有问题,打包 ...

随机推荐

  1. OpenStack手动从数据库中删除实例 - ugyn109的专栏 - 博客频道 - CSDN.NET

    由于某种原因我将OpenStack的一个计算节点移除了,但移除前并没有删除在其上运行的实例,后来想通过dash删除这些实例,于是N天过去了,我的dash还显示如下内容:很碍眼是不是?于是我打算手动从数 ...

  2. UVa 11624 Fire!(BFS)

    Fire! Time Limit: 5000MS   Memory Limit: 262144KB   64bit IO Format: %lld & %llu Description Joe ...

  3. HTTP 笔记与总结(7)HTTP 缓存(配合 Apache 服务器)

    在网络上,有一些缓存服务器,另外浏览器自身也有缓存功能. 例如: <!DOCTYPE html> <html lang="en"> <head> ...

  4. PHP 开发 APP 接口 学习笔记与总结 - APP 接口实例 [5] 版本设计分析及数据表设计

    APP 版本升级以及 APP 演示 ① 版本升级分析以及数据表设计 ② 版本升级接口开发以及 APP 演示 /** * version_upgrade 版本升级信息表 */ CREATE TABLE ...

  5. C#winfrom控件命名规范

     ※用红字标记的部分表示有重复出现,括号内为替代表示方案 1.标准控件 序号 控件类型简写 控件类型 1 btn Button 2 chk CheckBox 3 ckl CheckedListBox ...

  6. 超级有用的9个PHP代码片段

    在开发网站.app或博客时,代码片段可以真正地为你节省时间.今天,我们就来分享一下我收集的一些超级有用的PHP代码片段.一起来看一看吧! 1.创建数据URI 数据URI在嵌入图像到HTML / CSS ...

  7. MYSQL PASSWORD()

    https://www.pythian.com/blog/hashing-algorithm-in-mysql-password-2/ SELECT PASSWORD ("this_is_a ...

  8. Segmentation

    COMPUTER ORGANIZATION AND ARCHITECTURE DESIGNING FOR PERFORMANCE NINTH EDITION There is another way ...

  9. P1149 火柴棒等式

    #include <bits/stdc++.h> using namespace std; const int num[] = {6, 2, 5, 5, 4, 5, 6, 3, 7, 6} ...

  10. AP_总体业务及方案

    AP关键业务点说明 关键业务点 说明 预付款余额收回 1. 在应付款管理系统中输入一张虚拟发票,该发票的目的是在系统中冲减对供应商的预付款额,其金额等于预付款的未核销金额,供应商为原供应商. 借:其他 ...