亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

Chinaunix

標(biāo)題: 請教一下,這個shell如何寫? [打印本頁]

作者: enduser007    時(shí)間: 2012-11-09 11:07
標(biāo)題: 請教一下,這個shell如何寫?
我有一個文件,假定文件名為: input.txt
內(nèi)容大致如下:

....
.....

***********************************************************
******* PARA  1 INPUT  **************
***********************************************************
TEST  1356
    DIR                           /tmp
    username                       test
    data_dir                      /backup/test

.....


.....

***********************************************************
******* PARA  2 INPUT  **************
***********************************************************
TEST   1243
    DIR                           /tmp1
    username                       admin
    data_dir                      /backup/admin

.....

我想寫一個shell腳本,只南要輸入能數(shù)一個參數(shù),如1或2,腳本能根據(jù)參數(shù)情況,返回相應(yīng)段下邊的username后邊的值。

比如腳本為a.sh,執(zhí)行./a.sh 1 ,返回值是: test;  如果執(zhí)行./a.sh 2 ,返回值是: admin,依次類推。

我是新手,想了很久也不知道如何實(shí)現(xiàn),請輩們指點(diǎn)一下!

多謝!
作者: kk5234    時(shí)間: 2012-11-09 12:04
  1. #!/bin/bash
  2. output=$(sed -n "/PARA  $1 INPUT/{:b;N;s/.*username\s\+//p;t;$!bb}" input.txt)
  3. echo $output
復(fù)制代碼

作者: enduser007    時(shí)間: 2012-11-09 12:39
謝謝指教!


作者: love_shift    時(shí)間: 2012-11-09 13:09
  1. #!/bin/bash
  2. File="input.txt"
  3.    cat $File | grep "PARA  $1 INPUT" -C4 | grep "username" | awk '{ print $2 }'
復(fù)制代碼
新手來解答,來個比較容易看懂的。
作者: enduser007    時(shí)間: 2012-11-09 13:33
本帖最后由 enduser007 于 2012-11-09 13:50 編輯

樓上的兩位大俠,有沒有辦法改成,如要輸入的能數(shù)是:
admin返回PARA后邊哪個數(shù)字2,輸入?yún)?shù)test,返回PARA后邊的哪個數(shù)字1呢!


并且可能存在PARA 和數(shù)字及后邊的INPUT字符之間的空格數(shù)量不一定都是固定個數(shù),只是表明用空格分隔。

似乎上邊的兩個方法如果空格數(shù)量不固定好像提取不出來!


先謝謝兩位了
作者: yestreenstars    時(shí)間: 2012-11-09 13:55
回復(fù) 5# enduser007


    不管PARA與數(shù)字之間有多少個空格都可以:
  1. #!/bin/bash
  2. sed -nr "/PARA/{s/.*PARA\s+([0-9]+).*/\1/;h};/username/{/$1/{g;p}}" 1.txt
復(fù)制代碼

作者: dn833    時(shí)間: 2012-11-09 14:00
  1. [root@bogon tmp]# sh test1.sh test file
  2. 1
  3. [root@bogon tmp]# sh test1.sh admin file
  4. 2
  5. [root@bogon tmp]# sh test.sh 1 file
  6. test
  7. [root@bogon tmp]# sh test.sh 2 file
  8. admin
  9. [root@bogon tmp]# cat test.sh
  10. #!/bin/bash
  11. awk 'BEGIN{RS="******* PARA  ";FS="\n"}$1~/^'$1' INPUT/{gsub(/username| /,"");print $5}' $2
  12. [root@bogon tmp]# cat test1.sh
  13. #!/bin/bash
  14. awk 'BEGIN{RS="******* PARA  ";FS="\n"}$5~/'$1'/{gsub(/INPUT| |*/,"");print $1}' $2
  15. [root@bogon tmp]# cat file
  16. ***********************************************************
  17. ******* PARA  1 INPUT  **************
  18. ***********************************************************
  19. TEST  1356
  20.     DIR                           /tmp
  21.     username                       test
  22.     data_dir                      /backup/test

  23. .....


  24. .....

  25. ***********************************************************
  26. ******* PARA  2 INPUT  **************
  27. ***********************************************************
  28. TEST   1243
  29.     DIR                           /tmp1
  30.     username                       admin
  31.     data_dir                      /backup/admin

  32. .....
復(fù)制代碼

作者: enduser007    時(shí)間: 2012-11-09 14:06
回復(fù) 6# yestreenstars


    老兄,我這邊用你的代碼好像提取不了相關(guān)信息!

不知道為何
作者: yestreenstars    時(shí)間: 2012-11-09 14:14
回復(fù) 8# enduser007


重復(fù)檢查你的代碼,下面是在我的電腦上運(yùn)行的效果:



作者: enduser007    時(shí)間: 2012-11-09 14:52
本帖最后由 enduser007 于 2012-11-09 14:55 編輯

回復(fù) 9# yestreenstars


    不好意思,是我搞反了,

yestreenstars 老大,請?jiān)徫疫@個新手!讓你見笑了
但如果輸入的文件中有這樣一段,結(jié)果好像就不準(zhǔn)確了!

***********************************************************
******* PARA 2 INPUT  **************
***********************************************************
TEST   1243
    DIR                           /tmp1
    username                       admin
    data_dir                      /backup/admin

.....

***********************************************************
******* PARA 3 INPUT  **************
***********************************************************
TEST   1243f
    DIR                           /tmp1
    username                       admin1
    data_dir                      /backup/admin

.....

***********************************************************
******* PARA 4 INPUT  **************
***********************************************************
TEST   1fdsfs243f
    DIR                           /tmp1
    username                      org_admin
    data_dir                      /backup/admin3

.....
作者: yestreenstars    時(shí)間: 2012-11-09 15:04
回復(fù) 10# enduser007


    那就用這個腳本:
  1. #!/bin/bash
  2. awk '/PARA/{s=gensub(/.*PARA *([0-9]+).*/,"\\1",1)}/username/{if($2=="'$1'")print s}' 1.txt
復(fù)制代碼

作者: enduser007    時(shí)間: 2012-11-09 15:09
謝謝各位,問題已經(jīng)解決!

作者: 小鬼二豬    時(shí)間: 2012-11-12 15:27
grep "username" test.txt | sed -n "$1p" | awk '{print $2}'




歡迎光臨 Chinaunix (http://www.72891.cn/) Powered by Discuz! X3.2