在linux中使用awk把文件定长转换成分隔符,全部是空格变成一个空格显示。

在linux中使用awk把文件定长转换成分隔符,全部是空格变成一个空格显示。,第1张

echo "aaabbb   ccc   ddd" | sed -e 's/\(\{3\}\)/\1|/g' -e 's/ //g' -e 's/||/| |/g' -e 's/|$//'

一、内置变量表

属性

说明

$0

当前记录(作为单个变量)

$1~$n

当前记录的第n个字段,字段间由FS分隔

FS

输入字段分隔符

默认是空格

NF

当前记录中的字段个数,就是有多少列

NR

已经读出的记录数,就是行号,从1开始

RS

输入的记录他隔符默

认为换行符

OFS

输出字段分隔符

默认也是空格

ORS

输出的记录分隔符,默认为换行符

ARGC

命令行参数个数

ARGV

命令行参数数组

FILENAME

当前输入文件的名字

IGNORECASE

如果为真,则进行忽略大小写的匹配

ARGIND

当前被处理文件的ARGV标志符

CONVFMT

数字转换格式

%6g

ENVIRON

UNIX环境变量

ERRNO

UNIX系统错误消息

FIELDWIDTHS

输入字段宽度的空白分隔字符串

FNR

当前记录数

OFMT

数字的输出格式

%6g

RSTART

被匹配函数匹配的字符串首

RLENGTH

被匹配函数匹配的字符串长度

SUBSEP

34

2、实例

1、常用 *** 作

代码如下:

[chengmo@localhost

~]$

awk

'/^root/{print

$0}'

/etc/passwd

root:x:0:0:root:/root:/bin/bash

/^root/

为选择表达式,$0代表是逐行

2、设置字段分隔符号(FS使用方法)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":"}/^root/{print

$1,$NF}'

/etc/passwd

root

/bin/bash

FS为字段分隔符,可以自己设置,默认是空格,因为passwd里面是”:”分隔,所以需要修改默认分隔符。NF是字段总数,$0代表当前行记录,$1-$n是当前行,各个字段对应值。

3、记录条数(NR,FNR使用方法)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":"}{print

NR,$1,$NF}'

/etc/passwd

1

root

/bin/bash

2

bin

/sbin/nologin

3

daemon

/sbin/nologin

4

adm

/sbin/nologin

5

lp

/sbin/nologin

6

sync

/bin/sync

7

shutdown

/sbin/shutdown

……

NR得到当前记录所在行

4、设置输出字段分隔符(OFS使用方法)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":";OFS="^^"}/^root/{print

FNR,$1,$NF}'

/etc/passwd

1^^root^^/bin/bash

OFS设置默认字段分隔符

5、设置输出行记录分隔符(ORS使用方法)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":";ORS="^^"}{print

FNR,$1,$NF}'

/etc/passwd

1

root

/bin/bash^^2

bin

/sbin/nologin^^3

daemon

/sbin/nologin^^4

adm

/sbin/nologin^^5

lp

/sbin/nologin

从上面看,ORS默认是换行符,这里修改为:”^^”,所有行之间用”^^”分隔了。

6、输入参数获取(ARGC

,ARGV使用)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":";print

"ARGC="ARGC;for(k

in

ARGV)

{print

k"="ARGV[k];

}}'

/etc/passwd

ARGC=2

0=awk

1=/etc/passwd

ARGC得到所有输入参数个数,ARGV获得输入参数内容,是一个数组。

7、获得传入的文件名(FILENAME使用)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{FS=":";print

FILENAME}{print

FILENAME}'

/etc/passwd

/etc/passwd

FILENAME,$0-$N,NF

不能使用在BEGIN中,BEGIN中不能获得任何与文件记录 *** 作的变量。

8、获得linux环境变量(ENVIRON使用)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{print

ENVIRON["PATH"];}'

/etc/passwd

/usr/lib/qt-33/bin:/usr/kerberos/bin:/usr/lib/ccache:/usr/lib/icecc/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbi

n:/usr/java/jdk150_17/bin:/usr/java/jdk150_17/jre/bin:/usr/local/mysql/bin:/home/web97/bin

ENVIRON是子典型数组,可以通过对应键值获得它的值。

9、输出数据格式设置:(OFMT使用)

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{OFMT="%3f";print

2/3,12311111111;}'

/etc/passwd

0667

123111

OFMT默认输出格式是:%6g

保留六位小数,这里修改OFMT会修改默认数据输出格式。

10、按宽度指定分隔符(FIELDWIDTHS使用)

复制代码

代码如下:

[chengmo@localhost

~]$

echo

20100117054932

|

awk

'BEGIN{FIELDWIDTHS="4

2

2

2

2

3"}{print

$1"-"$2"-"$3,$4":"$5":"$6}'

2010-01-17

05:49:32

FIELDWIDTHS其格式为空格分隔的一串数字,用以对记录进行域的分隔,FIELDWIDTHS="4

2

2

2

2

2"就表示$1宽度是4,$2是2,$3是2

。这个时候会忽略:FS分隔符。

11、RSTART

RLENGTH使用

代码如下:

[chengmo@localhost

~]$

awk

'BEGIN{start=match("this

is

a

test",/[a-z]+$/);

print

start,

RSTART,

RLENGTH

}'

11

11

4

[chengmo@localhost

~]$

awk

'BEGIN{start=match("this

is

a

test",/^[a-z]+$/);

print

start,

RSTART,

RLENGTH

}'

0

0

–1

RSTART

被匹配正则表达式首位置,RLENGTH

匹配字符长度,没有找到为-1

以上是:awk的一些内置变量使用,希望有什么问题可以与我交流。

ipAddr=1921681100

echo ${ipAddr##}

这样就提取出了100。

Bash中字符串的掐头去尾方法:

# 表示掐头,% 表示去尾

助记:键盘上# 在前面,键盘上% 在后面。

单个#或%的表示最小匹配,双个#或%表示最大匹配。

也就是说,当匹配有多种方案的时候,选择匹配最大长度还是最小长度。

用awk也可以:

ifconfig eth0 | awk '/inet addr/{print $2}' | awk -F '{print $NF}'

目前用cshell本身没这功能,要借助工具,文本处理工具awk或sed,他们即是命令也是编程语言。

echo $job | awk '{print length($0)}'

像bash就可以直接用命令获取

你用VBS也可,用fso组件把计算结果输出到文本文件。cshell把他cat出来。

这是我写的

set a = `echo $job | awk '{print length($0)}'`

PAUSE $a

exit

你可以测试下

以上就是关于在linux中使用awk把文件定长转换成分隔符,全部是空格变成一个空格显示。全部的内容,包括:在linux中使用awk把文件定长转换成分隔符,全部是空格变成一个空格显示。、linux awk 内置变量使用介绍、shell脚本如何提取ip地址最后一位,如192.168.1.100中的100等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9716814.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存