一、split 初始化和类型强制 

awk的内建函数split允许你把一个字符串分隔为单词并存储在数组中。你可以自己定义域分隔符或者使用现在FS(域分隔符)的值。
格式:

split (string, array, field separator)
   split (string, array)  -->如果第三个参数没有提供,awk就默认使用当前FS值。

例1:替换分隔符

time="12:34:56"
out=`echo $time | awk '{split($0,a,":");print a[1],a[2],a[3]}'`
echo $out

例2:计算指定范围内的和(计算每个人1月份的工资之和)

$ cat test.txt
Tom     2012-12-11      car     5       3000
John    2013-01-13      bike    4       1000
vivi    2013-01-18      car     4       2800
Tom     2013-01-20      car     3       2500
John    2013-01-28      bike    6       3500
$ awk '{split($2,a,"-");if(a[2]==01){b[$1]+=$5}}END{for(i in b)print i,b[i]}' test.txt
vivi 2800
Tom 2500
John 4500

例3:

$ head industryList.txt
IT
IT,互联网
IT服务(系统/数据/维护)
IT服务(系统/数据/维护),专业服务/咨询(财会/法律/人力资源等)
IT服务(系统/数据/维护),专业服务/咨询(财会/法律/人力资源等),学术/科研,计算机软件
$ head industryList.txt | awk '{split($0, arr, ","); for (i in arr) print arr[i]}'
IT
IT
互联网
IT服务(系统/数据/维护)
IT服务(系统/数据/维护)
专业服务/咨询(财会/法律/人力资源等)
IT服务(系统/数据/维护)
专业服务/咨询(财会/法律/人力资源等)
学术/科研
计算机软件
$ cat industryList.txt | awk '{split($0, arr, ","); for (i in arr) print arr[i]}' | sed 's/ //g' | sort | uniq > industryList_split.txt

二、substr 截取字符串
        返回从起始位置起,指定长度之子字符串;若未指定长度,则返回从起始位置到字符串末尾的子字符串。
格式:
  substr(s,p) 返回字符串s中从p开始的后缀部分
  substr(s,p,n) 返回字符串s中从p开始长度为n的后缀部分
例子:

$ echo "123" | awk '{print substr($0,1,1)}'
1

解释:
awk -F ',' '{print substr($3,6)}'    --->  表示是从第3个字段里的第6个字符开始,一直到设定的分隔符","结束.
substr($3,10,8)  --->  表示是从第3个字段里的第10个字符开始,截取8个字符结束.
substr($3,6)     --->  表示是从第3个字段里的第6个字符开始,一直到结尾

三、length 字符串长度
   length函数返回没有参数的字符串的长度。length函数返回整个记录中的字符数。

$ echo "123" | awk '{print length}'
3

$ cat info.json | jq .industryList | awk -F '"' '{print $2}' | awk '{if (length > 0) print $0}' | sort | uniq > industryList.txt

四、gsub函数

gsub函数则使得在所有正则表达式被匹配的时候都发生替换。gsub(regular expression, subsitution string, target string);简称 gsub(r,s,t)。

举例:把一个文件里面所有包含 abc 的行里面的 abc 替换成 def,然后输出第一列和第三列

$ awk '$0 ~ /abc/ {gsub("abc", "def", $0); print $1, $3}' abc.txt

参考:

http://gdcsy.blog.163.com/blog/static/12734360920130241521280/

http://www.cnblogs.com/sunada2005/p/3493941.html

转载于:https://www.cnblogs.com/bymo/p/7601519.html

linux下awk内置函数的使用(split/substr/length)相关推荐

  1. linux string split,linux下awk内置函数的使用(split/substr/length)

    一.split 初始化和类型强制 awk的内建函数split允许你把一个字符串分隔为单词并存储在数组中.你可以自己定义域分隔符或者使用现在FS(域分隔符)的值. 格式: split (string, ...

  2. linux awk 内置函数详细介绍(实例)

    原文地址为: linux awk 内置函数详细介绍(实例) 这节详细介绍awk内置函数,主要分以下3种类似:算数函数.字符串函数.其它一般函数.时间函数 一.算术函数: 以下算术函数执行与 C 语言中 ...

  3. Linux常用基本命令:三剑客命令之-awk内置函数用法

    awk的内置函数大致可以分类为算数函数.字符串函数.时间函数.其他函数等 算数函数 最常用的算数函数有rand函数.srand函数.int函数. 可以使用rand函数生成随机数,但是使用rand函数时 ...

  4. linux向函数传值的例子,linux awk 内置函数详细介绍(实例)

    1. 字符转换 观察A S C I I码中6 5的等价值.管道输出6 5到a w k.p r i n t f进行A S C I I码字符转换.这里也加入换行,因为缺省情况下p r i n t f不做换 ...

  5. linux awk 内置变量实例

    awk 是一门非常优秀的文本处理工具,甚至可以上升作为一门程序设计语言. 它处理文本的速度是快得惊人的,现在很多基于shell 日志分析工具都可以用它完成.特点是设计简单,速度表现很好,本文将介绍aw ...

  6. python 两个内置函数——locals 和globals(名字空间)批量以自定义变量名创建对象

    文章目录 locals 和globals(名字空间)简介 1.局部变量函数locals例子(locals 返回一个名字/值对的字典) 批量创建对象 示例1 示例2 函数内 类内 2.全局变量函数glo ...

  7. GreenPlum7/PG12中如何添加一个自定义内置函数

    首先看下GP7内置函数处理机制:GP7的内置函数机制和GP6稍有不同.其中内置函数元数据信息来自pg_proc.dat.pg_proc.dat中是什么东西呢? ... ... 例如加法的函数int4_ ...

  8. awk的常用内置函数的使用【转】

    手把手教你在linux下熟悉使用awk的指令结构 (15) 大家好,今天和大家说一下awk吧.反正正则 早晚也要和大家说,不如一点一点和大家先交代清楚了,省得以后和大家说的时候,大家有懵的感觉... ...

  9. linux awk 内置变量使用介绍

    awk是个优秀文本处理工具,可以说是一门程序设计语言.下面是awk内置变量. 一.内置变量表 属性 说明 $0 当前记录(作为单个变量) $1~$n 当前记录的第n个字段,字段间由FS分隔 FS 输入 ...

最新文章

  1. Android Mvp 架构
  2. ZooKeeper入门之数据模型和常用命令介绍
  3. Jupyter notebook的内核是什么?Ipython
  4. IT十八掌作业_java基础第二天_进制转换原理和补码存储方式
  5. 64bit win7+VS2013+opencv2.4.9配置
  6. 一文看懂谷歌 NYC 算法与优化业务全景:三大项目组12个子领域详解(附重点论文下载)
  7. Redis Desktop Manager 利用ssh连接 Redis
  8. JAVA——基于HttpClient的正方教务系统[1999-2020]模拟登录基本解决方案
  9. 单例模式到Java内存模型
  10. 3.8 激活函数的导数
  11. 余额宝技术架构及演进
  12. mysql 复制协议_一种基于ISER协议的MySQL数据库复制方法与流程
  13. windows 2008之可重启的AD服务
  14. SpringBoot+Vue实现前后端分离的企业人事管理系统
  15. 怎么用燃尽图高效搞定项目进度监控?看老原这一篇就够了!
  16. python基础 -34- 面向对象(动态生成一个类)
  17. 2015阿里移动推荐算法大赛总结
  18. JavaSwing_3.2: JScrollPane(滚动面板)
  19. 国产紫光FPGA实现DDS信号发生器
  20. 吐血配置win7+theano+gpu+caffe+matlab+python

热门文章

  1. SpringBoot 根据传参返回不同的内容
  2. SpringBoot中的自定义路径怎么配置/根目录配置方法
  3. The template root requires exactly one element.
  4. Build path entry is missing 导致项目不编译。
  5. Apache Shiro去掉URL中的JSESSIONID
  6. PyTorch基础(一)-----张量(Tensor)
  7. hdu1232(简单并查集)
  8. 【译】Why Wayland on Android is a hard problem
  9. Android7.0 PowerManagerService亮灭屏分析(二)
  10. 【David Silver强化学习公开课】-3:DP