bash腳本編程之算術運算和文件查找

算數運算在每個編程語言里面是最基本的功能,在bash里面也是.相對于其他編程語言來說在bash里面不能直接以變量加上變量的形式來表現;比如我們先聲明兩個變量num1和num2然后再做運算。

num1=2
num2=3
echo "$num1+$num2"
2+3

這里我們顯示的結果直接為2+3只是做了變量的替換,而不是做兩個變量的加法運算;在bash里面變量默認是以字符串類型來存儲的;就算我們在這里聲明的這兩個變量為整數也不會做運算;declare命令-i可以聲明我們定義的變量為整型bash也只會做變量替換;

declare -i num3=9
declare -i num4=1
echo “$num3+$unm4”
9+1

對于bash來說要做算數運算必須使用特殊的算術運算格式:

1.使用let命令;例如

let $num1+$num2

這里不會顯示任何數據let命令默認是不會輸出結果至屏幕的;所以我們這里需要做變量賦值;將$num1+$num2的運算后的值,賦值個另外一個變量sum;

let $sum=$num1+$unm2
echo “$sum”
5

2.算術運算表達式用[]直接賦值給一個變量;這里可以賦值也可以直接使用

echo $[$num3+$num4]
10

也可以做賦值;

$sum=$[$num3+$num4]
echo "$sum"
10

3.使用兩個小括號和[]用法相似

$sum=$(($num3+$num4))
echo "$sum"

4.使用expr命令進行運算;將變量和運算符做參數傳遞給expr做運算;

$sum=$(expr $num3 + $num4)

注意這里既然是作為命令的參數運算的那個參數之間需要空格;

bash的運算符有+,-,,/,*(次方),%(取模)

乘法符號在bash里面有特殊含義,所以在有些場景里面需要使用轉義符

文件查找

在文件系統上查找符合條件的文件可使用的命令有:locate,find

locate

文件查找命令,其工作原理是依賴于事先構建好的索引庫.系統性的歷遍文件系統的所有文件路徑下的文件來構建這個庫,用戶在查找文件的時候不是直接去歷遍目標路徑而是直接來搜索這個索引庫;以節省系統資源;但是我們手動去更新索引庫的時候會消耗大量資源;

他的工作特性是:查找熟讀快,模糊查找,非實時查找;

手動更新索引庫updatedb

locate:查找文件系統上符合條件的文件
    locate  [OPTION]...  PATTERN...
    -b:至匹配路徑中的基名
    -c:統計出共多少個符合條件的文件
    -r:基本使用正則表達式

find命令

實時查找工具,通過遍歷指定的起始目錄下文件系統層級結構完成文件查找;與前面locate不同的是find是屬于實時查找,可以指定搜索目標的起始路徑,默認的是當前目錄;find的匹配條件是精確查找,可以根據文件名,大小,類型,從屬關系,權限等;而且可以對符合條件的文件作出刪除等操作,默認的是輸出至標準輸出;

工作特性:查找速度略慢;精確查找;實時查找

fnind:

find:
    find [OPTIONS] [查找起始路徑] [查找條件] [處理動作]

查找條件;

根據文件名查找:

-name “pattern” 

-iname “pattern“ :忽略大小寫

pattern支持glob風格的通配符;

-regex “pattern”:基于正則表達式查找文件,匹配的是路徑,并非文件名;

根據文件從屬關系查找:

-user USERNAME:查找屬主為指定用戶的所有文件;
-group GROUPNAME:查找屬組為指定組的所有文件;
-uid UID:查找屬主為指定UID的所有文件;
-gid GID:查找屬組為指定GID的所有文件;
-nouser:查找沒有屬主的文件;
-nogroup:查找沒有屬組的文件;

根據文件類型找找:

-type TYPE:
        f:普通文件;
        d:目錄文件;
        l:符號鏈接文件;
        b:塊設備文件;
        c:字符設備文件;
        p:管道文件;
        s:套接字文件;

根據文件的大小查找:

-size [+|-]#
    常用單位:K,M,G

根據時間戳查找:

以天為單位:
-atime [+|-]#
-mtime
-ctime
以分鐘為單位: 
-amin
-mmin   
-cmin

根據權限查找

-perm [/|-]mode
mode:精確權限匹配
/mode:任何一類用戶(u,g,o)權限中的任何一位(r,w,x)滿足其中一個就行;權限位之間存在或關系;
-mode:每一類用戶(u,g,o)權限中的的每一位(r,w,x)同時符合和條件才滿足;權限位之間存在與關系;

組合測試:

與:-a;默認組合邏輯;兩個條件都滿足為與;
或:-o;滿足兩個條件其中一只為或;
非:!;-not!取反

處理動作:

-print:輸出至標準輸出;默認的動作;
-ls:類似于對查找到的文件執行“ls -l”命令;顯示文件的詳細信息
-delete:刪除查找到的文件;
-fls /PSTH/TO/SOMEFILE:吧查找到的文件長格式信息保存至指定的的文件中;
-ok COMAND {} \; :對查找到的每個文件執行由COMAND表示的命令每次操作都由用戶確認;
-exec COMAND {} \; :對查找到的每個文件執行由CMOAND代表的命令;

練習:

1、找出/tmp目錄下屬主為非root的所有文件;

find /tmp/ -! -user root

2、找出/tmp目錄下文件名中不包含fstab字符串的文件

find / -name [^fstab]

3、找出/tmp目錄下屬主為非root,而且文件名不包含fstab字符串的文件;

find /tmp -! -user root -a -name [^fstab]

1、查找/var目錄下屬主為root,且屬組為mail的所有文件或目錄;

find /var/ -user root -a -group mail

2、查找/usr目錄下不屬于root, bin或hadoop的所有文件或目錄;用兩種方法

find /usr/ -not -user root -not -user bin -not -user hadoop

find /usr/ -not ( -user root -o -user bin -o -user hadoop )

3、查找/etc目錄下最近一周內其內容修改過,且屬主不是root用戶也不是hadoop用戶的文件或目錄;

find -atime -7 -a -not ( -user root -o -user hadoop )

4、查找當前系統上沒有屬或屬組,且最近一周內曾被訪問過的文件或目錄;

find / ( -nouser -o -nogroup ) -a -atime -7

5、查找/etc目錄下大于1M且類型為普通文件的所有文件;

find /etc/ -size +1M -a -type f

6、查找/etc目錄下所有用戶都沒有寫權限的文件;

find /etc/ -not -perm /222 -type f

7、查找/etc目錄至少有一類用戶沒有執行權限的文件

find /etc -not -perm /111 -type f

8、查找/etc/init.d/目錄下,所有用戶都有執行權限,且其它用戶有寫權限的所有文件;

find /etc/init.d/ -prem -113 -type f

原創文章,作者:N24-執念,如若轉載,請注明出處:http://www.www58058.com/64554

(0)
N24-執念N24-執念
上一篇 2016-12-23
下一篇 2016-12-23

相關推薦

  • 最簡單也最難:運維監控的最后1公里

    談運維我們不得不提監控,監控是運維的起點,也是難點。隨著IT架構逐漸復雜化,從前端到IT底層,中間涉及瀏覽器、網絡、服務器、操作系統、中間件、應用、數據庫等,每個環節廠商不盡相同。當出現異常需要定位哪個環節出了問題的時候,排查就耗時耗力,若使用優云監控產品,以上難題不再是問題。優云全棧運維監控覆蓋了所有環節的監控,真正做到監控無盲區,運維無隱患。 運維最后一…

    系統運維 2017-01-09
  • 創建用戶、用戶組

    創建用戶、用戶組                  1解釋Linux的安全模型   2解釋用戶帳號和組群帳號的目的   3用戶和組管理命令   4理解并設置文件權限 5默認權限 6特殊權限 …

    Linux干貨 2016-08-08
  • 網絡班N22期第六周博客作業

    請詳細總結vim編輯器的使用并完成以下練習題 打開文件: ~]# vim [options] [file ..]       +#:打開文件后,直接讓光標處于第#行       +/PART…

    Linux干貨 2016-09-26
  • 文件查找find和locate

            在Linux這個一切皆文件的系統中怎么能快速和精確的查找到文件,是我們必不可少的技能。而文件查找的命令可以讓我們在很短的時間內在文件系統中找到我們要查找的文件。這就是我們要掌握的,因此我來介紹一下文件查找的這兩個命令locate和find。 文件查找:在文件系統上…

    Linux干貨 2016-08-24
  • 權限管理

    權限管理 在linux中的每一個文件或目錄都包含有訪問權限,這些訪問權限決定了誰能訪問和如何訪問這些文件和目錄。 我們先來看看文件的屬性: 權限: r:可獲取文件數據(讀取文件) w:可修改文件的數據(寫入數據) x:可以把此文件提請內核啟動為一個進程 (執行) 文件的權限主要針對三類對象進行定義:  owner: 屬主, u  grou…

    Linux干貨 2016-08-05
  • vim簡單實用的技巧總結

    vi 和 vim無需過多的區分,vim可認為是vi的增強版。        這篇關于vim的手冊,我個人覺得實在無法把它寫成文章,只能以手冊的方式列舉出來,因為,vim是一個動手使用的工具,只能在使用中你才能慢慢發現它的操作多么符合邏輯,我從下面這些簡略的描述中,盡量將它的操作步驟寫出來,但更重要的…

    Linux干貨 2015-09-14
欧美性久久久久