亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

linux命令之目錄監(jiān)控 字符串拆分 監(jiān)控命令運(yùn)行結(jié)果 統(tǒng)計(jì)行數(shù) 去除文本頭尾空格 獲取網(wǎng)卡名浮點(diǎn)數(shù)運(yùn)算等命令使用技巧

 更新時(shí)間:2018年09月12日 15:05:03   投稿:wdc  
linux命令使用技巧之目錄監(jiān)控 字符串拆分 監(jiān)控命令運(yùn)行結(jié)果 統(tǒng)計(jì)行數(shù) 去除文本頭尾空格 獲取網(wǎng)卡名浮點(diǎn)數(shù)運(yùn)算等命令使用方法

上次為大家介紹了 Linux命令技巧之30個(gè)必會(huì)的命令技巧,今天再為大家介紹一些比較實(shí)用的命令使用技巧

1、監(jiān)控目錄,新創(chuàng)建的文件名追加到日志中

#要安裝inotify-tools軟件包
#!/bin/bash
MON_DIR=/opt
inotifywait -mq --format %f -e create $MON_DIR |\
while read files; do
echo $files >> test.log
done

2、find一次查找多個(gè)指定文件類(lèi)型

# find ./ -name '*.jpg' -o -name '*.png'
# find ./ -regex ".*\.jpg\|.*\.png"

3、字符串拆分

# echo "hello" |awk -F '' '{for(i=1;i<=NF;i++)print $i}'
# echo "hello" |sed 's/./&\n/g'
# echo "hello" |sed -r 's/(.)/\1\n/g'

4、實(shí)時(shí)監(jiān)控命令運(yùn)行結(jié)果

`# watch -d -n 1 'ifconfig'`

5、解決郵件亂碼問(wèn)題

# echo `echo "content" | iconv -f utf8 -t gbk` | mail -s "`echo "title" | iconv -f utf8 -t gbk`" xxx@jb51.net

注:通過(guò)iconv工具將內(nèi)容字符集轉(zhuǎn)換

6、在文本中每隔三行添加一個(gè)換行或內(nèi)容

# sed '4~3s/^/\n/' file
# awk '$0;NR%3==0{print "\n"}' file
# awk '{print NR%3?$0:$0 "\n"}' file

7、刪除匹配行及后一行或前一行

# sed '/abc/,+1d' file #刪除匹配行及后一行
# sed '/abc/{n;d}' file #刪除后一行
# tac file |sed '/abc/,+1d' |tac #刪除前一行

8、統(tǒng)計(jì)總行數(shù)

方法1 # wc -l file

方法2 # grep -c . file

方法3 # awk 'END{print NR}' file

方法4 # sed -n '$=' file

9、去除文本開(kāi)頭和結(jié)尾空格

# sed -i 's/^[ \t]*//;s/[ \t]*$//' file

10、給單個(gè)IP加單引號(hào)

# echo '10.10.10.1 10.10.10.2 10.10.10.3' |sed -r 's/[^ ]+/"&"/g'
# echo '10.10.10.1 10.10.10.2 10.10.10.3' |awk '{for(i=1;i<=NF;i++)printf "\047"$i"\047"}'

11、腳本中打印等待時(shí)間

wait(){
echo -n "wait 3s"
for ((i=1;i<=3;i++)); do
echo -n "."
sleep 1
done
echo
}
wait

12、刪除指定行

# awk 'NR==1{next}{print $0}' file #$0可省略
# awk 'NR!=1{print}' file
# awk 'NR!=1{print $0}' 或刪除匹配行:awk '!/test/{print $0}'
# sed '1d' file
# sed -n '1!p' file

13、在指定行前后加一行

在第二行前一行加txt:

# awk 'NR==2{sub('/.*/',"txt\n&")}{print}' a.txt 
# sed'2s/.*/txt\n&/' a.txt

在第二行后一行加txt:

# awk 'NR==2{sub('/.*/',"&\ntxt")}{print}' a.txt
# sed'2s/.*/&\ntxt/' a.txt

14、通過(guò)IP獲取網(wǎng)卡名

# ifconfig |awk -F'[: ]' '/^eth/{nic=$1}/192.168.18.15/{print nic}'

15、浮點(diǎn)數(shù)運(yùn)算(數(shù)字46保留小數(shù)點(diǎn))

# awk 'BEGIN{print 46/100}' 
0.46
# echo 46|awk '{print $0/100}'
0.46
# awk 'BEGIN{printf "%.2f\n",46/100}'
0.46
# echo 'scale=2;46/100' |bc|sed 's/^/0/'
0.46
# printf "%.2f\n" $(echo "scale=2;46/100" |bc)
0.46

16、浮點(diǎn)數(shù)比較

方法1:

if [ $(echo "4>3"|bc) -eq 1 ]; then
echo yes
else
echo no
fi

方法2:

if [ $(awk 'BEGIN{if(4>3)print 1;else print 0}') -eq 1 ]; then
echo yes
else
echo no
fi

17、替換換行符為逗號(hào)

$ cat a.txt
1:
2
3

替換后:1,2,3

方法1:

$ tr '\n' ',' < a.txt
$ sed ':a;N;s/\n/,/;$!b a' a.txt
$ sed ':a;$!N;s/\n/,/;t a' a.txt :

方法2:

while read line; do
a+=($line)
done < a.txt
echo ${a[*]} |sed 's/ /,/g'

方法3:

awk '{s=(s?s","$0:$0)}END{print s}' a.txt

三目運(yùn)算符(a?b:c),第一個(gè)s是變量,s?s","$0:$0,第一次處理1時(shí),s變量沒(méi)有賦值為假,結(jié)果打印1,第二次處理2時(shí),s值是1,為真,結(jié)果1,2。以此類(lèi)推,小括號(hào)可以不寫(xiě)。

awk '{if($0!=3)printf "%s,",$0;else print $0}' a.txt

18、windows下文本到linux下隱藏格式去除

方法1:打開(kāi)文件后輸入

:set fileformat=unix

方法2:打開(kāi)文件后輸入

:%s/\r*$// #^M可用\r代替

方法3:

sed -i 's/^M//g' a.txt #^M的輸入方式是ctrl+v,然后ctrl+m

方法4:

dos2unix a.txt

19、xargs巧用

xargs -n1 #將單個(gè)字段作為一行

# cat a.txt
1 2
3 4
# xargs -n1 < a.txt
1
2
3
4
xargs -n2 #將兩個(gè)字段作為一行
$ cat b.txt
string
number
a
1
b
2
$ xargs -n2 < a.txt
string number
a 1
b 2

20、統(tǒng)計(jì)當(dāng)前目錄中以.html結(jié)尾的文件總大小

方法1:

# find . -name "*.html" -maxdepth 1 -exec du -b {} \; |awk '{sum+=$1}END{print sum}'

方法2:

for size in $(ls -l *.html |awk '{print $5}'); do
sum=$(($sum+$size))
done
echo $sum

遞歸統(tǒng)計(jì):

# find . -name "*.html" -exec du -k {} \; |awk '{sum+=$1}END{print sum}'

這次主要介紹了linux中的目錄監(jiān)控 字符串拆分 監(jiān)控命令運(yùn)行結(jié)果 統(tǒng)計(jì)行數(shù) 去除文本頭尾空格 獲取網(wǎng)卡名浮點(diǎn)數(shù)運(yùn)算等命令使用方法,更多有趣的命令使用技巧請(qǐng)查看下面的相關(guān)文章

相關(guān)文章

最新評(píng)論