情景linux--如何得出一个文件的第二列?

情景linux--如何得出一个文件的第二列?,第1张

曾经有一同事问我,在linux下如何输出一个文本文件的第二列,文本内容不限。我不假思索地说用 awk 啊。她追问只有这一种方式么?于是我仔细想了想,……

既然内容不限,则可以自定义文件内容的格式,这样可以用的命令自然会多一些。

需求为输出文件第二列,则基本上有两种方式实现:

因而,任何能直接输出特定列的命令,以及能够截取或删除其它列的命令都满足此需求。

为了方便说明,列举几个示例文件:

awk自然是最容易想到的,它处理格式化的文本得心应手。

使用 -F 指定列(字段)分隔符。

如果文件只有两列,还可以使用 $NF ,如 awk '{print $NF}' test1.txt 。

awk还支持一些函数,同样可以将第二列提取出来,此处不再赘述。

cut命令的默认字段分隔符是 TAB ,可以使用 -d 重新指定。 -f 列出指定字段。

如果第二列的字符的起始和结束序号为固定值,如test2.txt,可以使用 -c 参数,截取特定的字符序列。

sed采用的是第二种实现方式,即将其它列删除掉,利用 后向引用 :

在test1.txt中,第二列的前面和后面分别为数字空格和空格数字,所以可以利用 正则表达式 将其输出出来。

同理:

colrm命令可以删除标准输入中的指定列,但 该命令中所定义的列指的是单个字符 ,这与常规对字段的定义不同,需注意。

格式如下:

如果只指定start,则大于等于start的列均被删除;如果指定了start和stop,则大于等于start,小于等于stop的列被删除。

因此,此命令可处理第二个字段起始位置为固定值的test2.txt文件。

read读取文件中的每行,将特定的列输出来。

shell支持命令替换,通过两次命令替换,得到第二列:

虽然不清楚她从哪里看到的这道题目,题目本身是何用意。但以一个问题,调动起了对linux多个命令及知识点的学习和总结,还是有价值的。

欢迎提出不同解法!

相关命令

#!/bin/bash

TotalFields=$(awk '{print NF}' file.txt|sort -nr|head -1) #获取file.txt的最大字段数量,假定文件名为 file.txt

k=1

for((i=1i<=$TotalFieldsi+=1))

do

cut -d" " -f${i}-$(((i+=3))) file.txt>file${k}  #-d后为各字段的分隔符,自己根据实际情况指定

((k++))

done

举个例子:

[root@localhost ~]# cat file.txt

aa bb cc dd ee ff gg cc dd o k g ookk

ca bb cc ddd dee fff dgg fcc ddd o k g ookk

aa abb dcc add ee ff gg cc dd do k g ookk

aaa bb cc ddd ebe fff dgg ccf dd o dk g ookk

aa bb cyc dd ee ff gg ccd ddd o fk g ookk

[root@localhost ~]# cat test.sh

#!/bin/bash

TotalFields=$(awk '{print NF}' file.txt|sort -nr|head -1)

k=1

for((i=1i<=$TotalFieldsi+=1))

do

cut -d" " -f${i}-$(((i+=3))) file.txt>file${k}

((k++))

done

[root@localhost ~]# ./test.sh

[root@localhost ~]# ls

anaconda-ks.cfg  cstudy  Desktop  file1  file2  file3  file4  file.txt  install.log  install.log.syslog  jdk-6u45-linux-x64.bin  test.sh  VBoxLinuxAdditions.run  Work

[root@localhost ~]# cat file1

aa bb cc dd

ca bb cc ddd

aa abb dcc add

aaa bb cc ddd

aa bb cyc dd

[root@localhost ~]# cat file2

ee ff gg cc

dee fff dgg fcc

ee ff gg cc

ebe fff dgg ccf

ee ff gg ccd

[root@localhost ~]# cat file3

dd o k g

ddd o k g

dd do k g

dd o dk g

ddd o fk g

[root@localhost ~]# cat file4

ookk

ookk

ookk

ookk

ookk

1、首先,连接相应linux主机,进入到linux命令行状态下,等待输入shell指令。

2、在linux命令行下输入shell指令:wc -l test.txt。

3、键盘按“回车键”运行shell指令,此时会看到test.txt共有8行数据。


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

原文地址:https://54852.com/yw/8788488.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存