1. 程式人生 > >六周第五次課(1月19日)

六周第五次課(1月19日)

ask 引號 awk 時間 test wid radius 一行 file

六周第五次課(1月19日)

復習

擴展

awk 中使用外部shell變量http://ask.apelearn.com/question/199

如:
A=44echo "ABCD" | awk -v GET_A=$A ’{print GET_A}’
說明:-v選項用於定義參數,這裏表示將變量A的值賦予GET_A。
有多少個變量需要賦值,就需要多少個-v選項。與之等價的:應用於腳本中:

#! /bin/bash
sort -n filename |awk -F ':' '{print $1}'|uniq >id.txt
for id in `cat id.txt`; do


echo "[$id]"
awk -v id2=$id -F ':' '$1==id2 {print $2}' filename // 另外的方式為: awk -F ':' '$1=="'id'" {print $2}' filename
done
附件:
cat filename
1111111:13443253456
2222222:13211222122
1111111:13643543544
3333333:12341243123
2222222:12123123123

運行腳本後結果為:
[1111111]
13443253456
13643543544
[2222222]
13211222122
12123123123
[3333333]
12341243123

awk 合並一個文件 http://ask.apelearn.com/question/493

需求,需要把兩個文件中,第一列相同的行合並到同一行中。舉個例子,有兩個文件,內容如下
cat 1.txt
1 aa
2 bb
3 ee
4 ss

cat 2.txt
1 ab
2 cd
3 ad
4 bd
5 de

合並後的結果為:

1 ab aa
2 cd bb
3 ad ee
4 bd ss
5 de

實現的命令為:
awk 'NR==FNR{a[$1]=$2}NR>FNR{print $0,a[$1]}' 1.txt 2.txt



解釋:NR表示讀取的行數,FNR表示讀取的當前行數
所以其實NR==FNR 就表示讀取2.txt的時候。 同理NR>FNR表示讀取1.txt的時候
數組a其實就相當於一個map

把一個文件多行連接成一行 http://ask.apelearn.com/question/266

a=`cat file`;echo $a
awk '{printf("%s ",$0)}' file // %s 後記得要有一空格,否則出來就是完全連在一起的,中間連空格都沒有
cat file |xargs

awk中gsub函數的使用 http://ask.apelearn.com/question/200

awk 'gsub(/www/,"abc")' /etc/passwd // passwd文件中把所有www替換為abc
awk -F ':' 'gsub(/www/,"abc",$1) {print $0}' /etc/passwd // 替換$1中的www為abc

awk 截取指定多個域為一行 http://ask.apelearn.com/question/224

for j in `seq 0 20`; do
let x=100*$j
let y=$x+1
let z=$x+100
for i in `seq $y $z` ; do
awk -v a=$i '{printf $a " "}' example.txt >>/tmp/test.txt
echo " " >>/tmp/test.txt
done
done

過濾兩個或多個關鍵詞 http://ask.apelearn.com/question/198

grep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行
egrep '123|abc' filename //用egrep同樣可以實現
awk '/123|abc/' filename // awk 的實現方式

用awk生成以下結構文件 http://ask.apelearn.com/question/5494

用awk編寫生成以下結構文件的程序。( 最後列使用現在的時間,時間格式為YYYYMMDDHHMISS) 各列的值應如下所示,每增加一行便加1,共500萬行。

1,1,0000000001,0000000001,0000000001,0000000001,0000000001,0000000001,2005100110101
2,2,0000000002,0000000002,0000000002,0000000002,0000000002,0000000002,2005100110101

awk用print打印單引號 http://ask.apelearn.com/question/1738

awk '{print "This is a '"'"'"$1} filename
解釋一下:在awk中使用脫義字符\是起不到作用的,如果想打印特殊字符,只能使用'""' 這樣的組合才可以。
這裏自左至右為單引號 雙引號 雙引號 單引號其中兩個單引號為一對,兩個雙引號為一對。想脫義$那就是'"$"' 脫義單引號那就是 '"'"'

合並兩個文件 http://ask.apelearn.com/question/945

paste filename1 filename2

這樣就可以實現了。舉個例子。
cat a.txt
1 2 3
4 5 6
a b c

cat b.txt
3 2 1
6 5 4
c b a

則 paste a.txt b.txt 結果為
1 2 3 3 2 1
4 5 6 6 5 4
a b c c b a

如果,你想在兩個文件連接處用一個指定的字符連接,還可以用-d來指定
paste -d '+' a.txt b.txt
結果為
1 2 3+3 2 1
4 5 6+6 5 4
a b c+c b a



awk的參考教程 http://www.cnblogs.com/emanlee/p/3327576.html


六周第五次課(1月19日)