linux脚本怎么读取文本的某一列进行操作

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux脚本怎么读取文本的某一列进行操作相关的知识,希望对你有一定的参考价值。

cat ip.txt
172.16.0.221 b
172.16.0.225 c

ping ip.txt每行的第一列,把piing结果的一些字段+ ip.txt的2列值 显示出来。
我只会ip.txt只有一列的情况,且显示结果没有包括ip.txt的第2列
#!/bin/sh
while read LINE;
do
ping -c 1 $LINE| grep -1 "transmitted"| sed 'N;N;s/\n/ /g'| awk -F",| " 'print $2,$10,$13,$18,$22' | awk -F"/" 'print $1,$2,$3,$4';
done<ip.txt

运行结果:
[root@localhost tmp]# ./test.sh
172.16.0.221 1 0% 0ms 0.025 0.025 0.025 0.000
172.16.0.225 1 0% 0ms 0.199 0.199 0.199 0.000

对ip.txt有2列的情况该怎么写?我要的运行结果是:
172.16.0.221 a 1 0% 0ms 0.025 0.025 0.025 0.000
172.16.0.225 b 1 0% 0ms 0.199 0.199 0.199 0.000
上面写错了,我要的运行结果是:
172.16.0.221 b 1 0% 0ms 0.025 0.025 0.025 0.000
172.16.0.225 c 1 0% 0ms 0.199 0.199 0.199 0.000

[root@dba ~]# cat ip.txt
192.168.1.1 b
192.168.1.1 c
[root@dba ~]# cat a.sh
#!/bin/bash
while read LINE;
do
echo -e "$LINE `ping -c 1 $LINE| grep -1 "transmitted"| sed 'N;N;s/\n/ /g'| awk -F",| " 'print $10,$13,$18,$22' | awk -F"/" 'print $1,$2,$3,$4';`"
done<ip.txt
[root@dba ~]# ./a.sh
192.168.1.1 b 1 0% 0ms 0.864 0.864 0.864 0.000
192.168.1.1 c 1 0% 0ms 0.829 0.829 0.829 0.000

是这意思不?

取某列的话,取出来放到一个临时文件里,然后想怎么操作就怎么操作,然后再把临时文件删了,方法可以有很多种,关键是根据各种环境灵活运用啊
[root@dba ~]# cat ip.txt
192.168.1.1 b
192.168.1.1 c
[root@dba ~]# awk -F " " 'print $2' ip.txt > temp.txt
[root@dba ~]# cat temp.txt
b
c
[root@dba ~]# sed '2s/[a-z]/999/g' temp.txt
b
999
[root@dba ~]# rm -rf temp.txt

是这意思不?觉得可以给好评啊亲!追问

用你的代码运行结不对,因为ping -c 1 $LINE 这变成ping -c 1 172.16.0.221 b 而不是ping -c 1 172.16.0.221 会ping不通。
用下面这个别人教我的就可以了
#!/bin/sh
while read a b;
do
result=`ping -c 1 $a| grep -A1 "transmitted"| sed 'N;s/\n/ /g'| awk -F",| " 'print $5,$8,$13,$17,$22'| awk -F"/" 'print $1,$2,$3,$4'`;
echo "$a $b $result"
done < ip.txt

追答

有图有真相,自己看吧,不说了,心情低落=。=被质疑的感觉真不怎么好,嗯

参考技术A 这种稍微复杂了的工作还是交给ruby, python等辈去做吧, 写/读/维护都容易...

linux 中可以用cut提取某一行的某一列数据吗? 如果可以怎么做?

cut -d" " -f2 filename
意思就是我以空格为列的分隔符,提取第二列

或者使用awk
awk 'print $2' filename
awk默认以空格为分隔符,打印第二列
参考技术A cut -d" " -f2 filename
意思就是我以空格为列的分隔符,提取第二列
或者使用awk
awk 'print $2' filename
awk默认以空格为分隔符,打印第二列。《Linux就该这么学》里有相关介绍,建议看看。本回答被提问者采纳

以上是关于linux脚本怎么读取文本的某一列进行操作的主要内容,如果未能解决你的问题,请参考以下文章

winform中怎么读取DataGridview中特定的某一列并赋值给一个数组?

怎么用C/C++语言读取excel文件的某一行某一列

Linux:使用awk命令获取文本的某一行,某一列

如何取矩阵的某一行,或某一列

linux环境下根据文件的某一列进行去重

python中对csv文件某一列的每一行文本进行分词后再写到该文件另一列怎么做