久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1771|回復: 0
打印 上一主題 下一主題
收起左側

grep命令

[復制鏈接]
跳轉到指定樓層
樓主
ID:107189 發表于 2016-3-6 15:19 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
既然要使用 grep 當然就得要先了解一下 grep 的語法啰~
[root@test root]# grep [-acinv] '搜尋字符串' filename
參數說明:
-a :將 binary 檔案以 text 檔案的方式搜尋數據
-c :計算找到 '搜尋字符串' 的次數
-i :忽略大小寫的不同,所以大小寫視為相同
-n :順便輸出行號
-v :反向選擇,亦即顯示出沒有 '搜尋字符串' 內容的那一行!
范例:
[root@test root]# grep 'root' /var/log/secure
將 /var/log/secure 這個檔案中有 root 的那一行秀出來

[root@test root]# grep -v 'root' /var/log/secure
若該行沒有 root 才將數據秀出來到屏幕上!

[root@test root]# last | grep root
若該行有 root 才將數據秀出來到屏幕上!

grep 是一個很常見也很常用的指令,他最重要的功能就是進行字符串數據的比對, 然后將符合使用者需求的字符串打印出來。 需要說明的是『grep 在資料中查尋一個字符串時,是以 "整行" 為單位來進行數據的擷取的!』也就是說,假如一個檔案內有 10 行,其中有兩行具有你所搜尋的字符串,則將那兩行顯示在屏幕上,其它的就丟棄了!

而 grep 除了可以進行檔案的資料搜尋之外,也常常被應用在 input/output 的數據處理當中,例如常見的 管線命令 ( pipe ) 就可以常常見到他的蹤影! 以上面表格中的例子來看,我們可以發現前兩個例子是查尋檔案的內容,有沒有加上 -v 所顯示出來的結果是『相反的!』,而第三個例子則是以 pipe 的功能進行數據的處理的喔!

好了,我們就開始以 grep 來進行正規表示法的簡易說明吧!我們先以底下這個檔案來作為范例:

[root@test root]# vi regular_express.txt
"Open Source" is a good mechanism to develop programs.
apple is my favorite food.
Football game is not use feet only.
this dress doesn't fit me.
However, this dress is about $ 3183 dollars.
GNU is free air not free beer.
Her hair is very beauty.
I can’t finish the test.
Oh! The soup taste good.
motorcycle is cheap than car.
This window is clear.
the symbol '*' is represented as start.
Oh! My god!
The gd software is a library for drafting programs.
You are the best is mean you are the no. 1.
The world is the same with "glad".
I like dog.
google is the best tools for search keyword.
goooooogle yes!
go! go! Let's go.
# I am VBird


需要特別注意的是,上面這個檔案鳥哥是在 Windows 的環境下編輯的, 并且經過特殊處理過,因此,他雖然是純文字文件,但是內含一些 Windows 環境下的軟件常常自行加入的一些特殊字符,例如斷行字符(^M)就是一例! 所以,您可以直接將上面的文字以 vi 儲存成 regular_express.txt 這個檔案, 不過,比較建議直接點底下的連結下載:

此外,因為不同的語系編碼是不一樣的,所以,您必須要將語系改成英文語系, 才能夠進行底下的測試,否則,可能會有顯示的內容與底下的輸出不符的狀況喔! 修改語系的方法為:
[root@test root]# LANG=en
[root@test root]# export LANG
好了,現在開始我們一個案例一個案例的來介紹吧!
  • 例題一、搜尋特定字符串:
    搜尋特定字符串很簡單吧?假設我們要從剛剛的檔案當中取得 the 這個特定字符串, 最簡單的方式就是這樣:
    [root@test root]# grep -n 'the' regular_express.txt
    8:I can't finish the test.
    12:the symbol '*' is represented as start.
    15:You are the best is mean you are the no. 1.
    16:The world  is the same with "glad".
    18:google is the best tools for search keyword.
    那如果想要『反向選擇』呢?也就是說,當該行沒有 'the' 這個字符串時,才顯示在屏幕上,那就直接使用:
    [root@test root]# grep -vn 'the' regular_express.txt
    您會發現,屏幕上出現的行列為除了 8,12,15,16,18 五行之外的其它行列! 接下來,如果您想要取得不論大小寫的 the 這個字符串,則:
    [root@test root]# grep -in 'the' regular_express.txt
    8:I can't finish the test.
    9:Oh! The soup taste good.
    12:the symbol '*' is represented as start.
    14:The gd software is a library for drafting programs.
    15:You are the best is mean you are the no. 1.
    16:The world  is the same with "glad".
    18:google is the best tools for search keyword.
  • 例題二、利用 [] 來搜尋集合字符
    如果我想要搜尋 test 或 taste 這兩個單字時,可以發現到,其實她們有共通的 't?st' 存在~這個時候,我可以這樣來搜尋:
    [root@test root]# grep -n 't[ae]st' regular_express.txt
    8:I can't finish the test.
    9:Oh! The soup taste good.
    了解了吧?其實 [] 里面不論有幾個字符,他都謹代表某『一個』字符, 所以,上面的例子說明了,我需要的字符串是『tast』或『test』兩個字符串而已! 而如果想要搜尋到有 oo 的字符時,則使用:
    [root@test root]# grep -n 'oo' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    2:apple is my favorite food.
    3:Football game is not use feet only.
    9:Oh! The soup taste good.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    但是,如果我不想要 oo 前面有 g 的話呢?此時,可以利用在集合字符的反向選擇 [^] 來達成
    [root@test root]# grep -n '[^g]oo' regular_express.txt
    2:apple is my favorite food.
    3:Football game is not use feet only.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    意思就是說,我需要的是 oo ,但是 oo 前面不能是 g 就是了! 仔細比較上面兩個表格,妳會發現,第 1,9 行不見了,因為 oo 前面出現了 g 所致! 第 2,3 行沒有疑問,因為 foo 與 Foo 均可被接受!但是第 18 行明明有 google 的 goo 啊~ 別忘記了,因為該行后面出現了 tool 的 too 啊!所以該行也被列出來~ 也就是說, 18 行里面雖然出現了我們所不要的項目 (goo) 但是由于有需要的項目 (too) , 因此,是符合字符串搜尋的喔!

    至于第 19 行,同樣的,因為 goooooogle 里面的 oo 前面可能是 o ,例如: go(ooo)oogle ,所以,這一行也是符合需求的!

    再來,假設我 oo 前面不想要有小寫字符,所以,我可以這樣寫 [^abcd....z]oo , 但是這樣似乎不怎么方便,由于小寫字符的 ASCII 上編碼的順序是連續的, 因此,我們可以將之簡化為底下這樣:
    [root@test root]# grep -n '[^a-z]oo' regular_express.txt
    3:Football game is not use feet only.
    也就是說,當我們在一組集合字符中,如果該字符組是連續的,例如大寫英文/小寫英文/數字等等, 就可以使用[a-z],[A-Z],[0-9]等方式來書寫,那么如果我們的要求字符串是數字與英文呢? 呵呵!就將他全部寫在一起,變成:[a-zA-Z0-9]

    例如,我們要取得有數字的那一行,就這樣:
    [root@test root]# grep -n '[0-9]' regular_express.txt
    5:However, this dress is about $ 3183 dollars.
    15:You are the best is mean you are the no. 1.
    這樣對于 [] 以及 [^] 以及 [] 當中的 - 有了解了嗎?! ^_^y
  • 例題三、行首與行尾字符 ^ $:
    我們在例題一當中,可以查詢到一行字符串里面有 the 的,那如果我想要讓 the 只在行首列出呢? 這個時候就得要使用定位字符了!我們可以這樣做:
    [root@test root]# grep -n '^the' regular_express.txt
    12:the symbol '*' is represented as start.
    此時,就只剩下第 12 行,因為只有第 12 行的行首是 the 開頭啊~此外, 如果我想要開頭是小寫字符的那一行就列出呢?可以這樣:
    [root@test root]# grep -n '^[a-z]' regular_express.txt
    2:apple is my favorite food.
    4:this dress doesn't fit me.
    10:motorcycle is cheap than car.
    12:the symbol '*' is represented as start.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    如果我不想要開頭是英文字母,則可以是這樣:
    [root@test root]# grep -n '^[^a-zA-Z]' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    20:# I am VBird
    注意到了吧?那個 ^ 符號,在字符集合符號(括號[])之內與之外是不同的! 在 [] 內代表『反向選擇』,在 [] 之外則代表定位在行首的意義!要分清楚喔!

    那如果我想要找出來,行尾結束為小數點 (.) 的那一行,該如何處理:
    [root@test root]# grep -n '\.$' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    2:apple is my favorite food.
    3:Football game is not use feet only.
    4:this dress doesn't fit me.
    10:motorcycle is cheap than car.
    11:This window is clear.
    12:the symbol '*' is represented as start.
    15:You are the best is mean you are the no. 1.
    16:The world  is the same with "glad".
    17:I like dog.
    18:google is the best tools for search keyword.
    特別注意到,因為小數點具有其它意義(底下會介紹),所以必須要使用跳脫字符(\)來加以解除其特殊意義! 不過,您或許會覺得奇怪,但是第 5~9 行最后面也是 . 啊~怎么無法打印出來?? 這里就牽涉到 Windows 平臺的軟件對于斷行字符的判斷問題了!我們使用 cat -A 將第五行拿出來看, 您會發現:
    [root@test root]# cat -A regular_express.txt
    However, this dress is about $ 3183 dollars.^M$
    注意到了沒?最后面的斷行字符應該是 $ 才對,但是,因為 Windows 的 nodepad 會主動加上 ^M 作為斷行的判斷,因此,那個 . 自然就不是緊接在 $ 之前喔!這樣可以了解 ^ 與 $ 的意義嗎? 好了,先不要看底下的解答,自己想一想,那么如果我想要找出來,哪一行是『空白行』, 也就是說,該行并沒有輸入任何數據,該如何搜尋??
    [root@test root]# grep -n '^$' regular_express.txt
    21:
    因為只有行首跟行尾( ^$ ),所以,這樣就可以找出空白行啦!再來, 假設您已經知道在一個批次腳本 (shell script) 或者是設定檔當中, 空白行與開頭為 # 的那一行是批注,因此如果您要將數據列出給別人參考時, 可以將這些數據省略掉,以節省保貴的紙張,那么,您可以怎么作呢? 我們以 /etc/syslog.conf 這個檔案來作范例,您可以自行參考一下輸出的結果:
    [root@test root]# cat /etc/syslog.conf
    [root@test root]# grep -v '^$' /etc/syslog.conf | grep -v '^#'
    是否節省很多版面啊??
  • 例題四、任意一個字符 . 與重復字符 *
    在 bash 的章節當中,我們知道萬用字符 * 可以用來代表任意(0或多個)字符, 但是正規表示法并不是萬用字符,兩者之間是不相同的! 至于正規表示法當中的『 . 』則代表『絕對有一個任意字符』的意思!這樣講不好懂, 我們直接做個練習吧!假設我需要找出 g??d 的字符串,亦即共有四個字符, 起頭是 g 而結束是 d ,我可以這樣做:
    [root@test root]# grep -n 'g..d' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    9:Oh! The soup taste good.
    16:The world  is the same with "glad".
    因為強調 g 與 d 之間一定要存在兩個字符,因此,第 13 行的 god 與第 14 行的 gd 就不會被列出來啦!再來,如果我想要列出有 oo, ooo, oooo 等等的資料, 也就是說,至少要有兩個 o 以上,該如何是好??是 o* 還是 oo* 還是 ooo* 呢? 雖然您可以試看看結果, 不過結果太占版面了 @_@ ,所以,我這里就直接說明。

    因為 * 代表的是『重復 0 個或多個前面的 RE 字符』的意義, 因此,『o*』代表的是:『擁有空字符或一個 o 以上的字符』, 特別注意,因為允許空字符(就是有沒有字符都可以的意思),因此, grep -n 'o*' regular_express.txt 將會把所有的數據都打印出來屏幕上!

    那如果是『oo*』呢?則第一個 o 肯定必須要存在,第二個 o 則是可有可無的多個 o , 所以,凡是含有 o, oo, ooo, oooo 等等,都可以被列出來~

    同理,當我們需要『至少兩個 o 以上的字符串』時,就需要 ooo* ,亦即是:
    [root@test root]# grep -n 'ooo*' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    2:apple is my favorite food.
    3:Football game is not use feet only.
    9:Oh! The soup taste good.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    這樣理解 * 的意義了嗎?!好了,現在出個練習,如果我想要字符串開頭與結尾都是 g, 但是兩個 g 之間僅能存在至少一個 o ,亦即是 gog, goog, gooog.... 等等, 那該如何?
    [root@test root]# grep -n 'goo*g' regular_express.txt
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    如此了解了嗎?好,再來一題,如果我想要找出 g 開頭與 g 結尾的字符串, 當中的字符可有可無,那該如何是好?是『g*g』嗎?
    [root@test root]# grep -n 'g*g' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    3:Football game is not use feet only.
    9:Oh! The soup taste good.
    13:Oh!  My god!
    14:The gd software is a library for drafting programs.
    16:The world  is the same with "glad".
    17:I like dog.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    但測試的結果竟然出現這么多行??太詭異了吧? 其實一點也不詭異,因為 g*g 里面的 g* 代表『空字符或一個以上的 g』 在加上后面的 g ,因此,整個 RE 的內容就是 g, gg, ggg, gggg , 因此,只要該行當中擁有一個以上的 g 就符合所需了!

    那該如何得到我們的 g....g 的需求呢?呵呵!就利用任意一個字符『.』啊! 亦即是:『g.*g』的作法,因為 * 可以是 0 或多個重復前面的字符,而 . 是任意字符,所以: 『.* 就代表零個或多個任意字符』的意思啦!
    [root@test root]# grep -n 'g.*g' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    14:The gd software is a library for drafting programs.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    因為是代表 g 開頭與 g 結尾,中間任意字符均可接受,所以,第 1 與第 14 行是可接受的喔! 這個 .* 的 RE 表示任意字符是很常見的,希望大家能夠理解并且熟悉!

    再出一題,如果我想要找出『任意數字』的行列呢?因為僅有數字,所以就成為:
    [root@test root]# grep -n '[0-9][0-9]*' regular_express.txt
    5:However, this dress is about $ 3183 dollars.
    15:You are the best is mean you are the no. 1.
    雖然使用 grep -n '[0-9]' regular_express.txt 也可以得到相同的結果, 但鳥哥希望大家能夠理解上面指令當中 RE 表示法的意義才好!
  • 例題五、限定連續 RE 字符范圍 {}
    在上個例題當中,我們可以利用 . 與 RE 字符及 * 來設定 0 個到無線多個重復字符, 那如果我想要限制一個范圍區間內的重復字符數呢?舉例來說,我想要找出兩個到五個 o 的連續字符串,該如何作?這時候就得要使用到限定范圍的字符 {} 了。 但因為 { 與 } 的符號在 shell 是有特殊意義的,因此, 我們必須要使用跳脫字符 \ 來讓他失去特殊意義才行。

    至于 {} 的語法是這樣的,假設我要找到兩個 o 的字符串,可以是:
    [root@test root]# grep -n 'o\{2\}' regular_express.txt
    1:"Open Source" is a good mechanism to develop programs.
    2:apple is my favorite food.
    3:Football game is not use feet only.
    9:Oh! The soup taste good.
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    這樣看似乎與 ooo* 的字符沒有什么差異啊?因為第 19 行有多個 o 依舊也出現了! 好,那么換個搜尋的字符串,假設我們要找出 g 后面接 2 到 5 個 o ,然后再接一個 g 的字符串, 他會是這樣:
    [root@test root]# grep -n 'go\{2,5\}g' regular_express.txt
    18:google is the best tools for search keyword.
    嗯!很好!第 19 行終于沒有被取用了(因為 19 行有 6 個 o 啊!)。 那么,如果我想要的是 2 個 o 以上的 goooo....g 呢?除了可以是 gooo*g ,也可以是:
    [root@test root]# grep -n 'go\{2,\}g' regular_express.txt
    18:google is the best tools for search keyword.
    19:goooooogle yes!
    呵呵!就可以找出來啦~

◎grep -- print lines matching a pattern
grep [options] PATTERN [FILE...]
grep [options] [-e PATTERN | -f FILE] [FILE...]
    grep用以在file內文中比對相對應的部分,或是當沒有指定檔案時,由標準輸入中去比對。 在預設的情況下,grep會將符合樣式的那一行列出。
    此外,還有兩個程式是grep的變化型,egrep及fgrep其中egrep就等同於grep -E ,fgrep等同於grep -F 。
◎參數
    1. -A NUM,--after-context=NUM  
        除了列出符合行之外,并且列出后NUM行。   
         ex:   $ grep -A 1 panda file  
               (從file中搜尋有panda樣式的行,并顯示該行的后1行)
                                 
    2. -a或--text   
         grep原本是搜尋文字檔,若拿二進位的檔案作為搜尋的目標,
         則會顯示如下的訊息: Binary file 二進位檔名 matches 然后結束。
                  
         若加上-a參數則可將二進位檔案視為文字檔案搜尋,
         相當於--binary-files=text這個參數。
            
         ex:   (從二進位檔案mv中去搜尋panda樣式)
               (錯誤!!!)
         $ grep panda mv  
         Binary file mv matches   
         (這表示此檔案有match之處,詳見--binary-files=TYPE )
         $ (正確!!!)
         $ grep -a panda mv  
        
    3. -B NUM,--before-context=NUM
         與 -A NUM 相對,但這此參數是顯示除符合行之外
         并顯示在它之前的NUM行。         
              
         ex:   (從file中搜尋有panda樣式的行,并顯示該行的前1行)
         $ grep -B 1 panda file  
    4. -C [NUM], -NUM, --context[=NUM]   
         列出符合行之外并列出上下各NUM行,預設值是2。
              
         ex:   (列出file中除包含panda樣式的行外并列出其上下2行)
               (若要改變預設值,直接改變NUM即可)
               $ grep -C[NUM]  panda file  
              
    5. -b, --byte-offset
       列出樣式之前的內文總共有多少byte ..
               
        ex:  $ grep -b  panda file   
         顯示結果類似於:
         0:panda
        66:pandahuang
       123:panda03
            
    6. --binary-files=TYPE
        此參數TYPE預設為binary(二進位),若以普通方式搜尋,只有2種結果:
        1.若有符合的地方:顯示Binary file 二進位檔名 matches
        2.若沒有符合的地方:什麼都沒有顯示。
                    
        若TYPE為without-match,遇到此參數,
        grep會認為此二進位檔案沒有包含任何搜尋樣式,與-I 參數相同。
                    
        若TPYE為text, grep會將此二進位檔視為text檔案,與-a 參數相同。
         
        Warning: --binary-files=text 若輸出為終端機,可能會產生一些不必要的輸出。
               
    7. -c, --count
       不顯示符合樣式行,只顯示符合的總行數。
       若再加上-v,--invert-match,參數顯示不符合的總行數。
    8. -d ACTION, --directories=ACTION
               若輸入的檔案是一個資料夾,使用ACTION去處理這個資料夾。
       預設ACTION是read(讀取),也就是說此資料夾會被視為一般的檔案;
       若ACTION是skip(略過),資料夾會被grep略過:
       若ACTION是recurse(遞),grep會去讀取資料夾下所有的檔案,
       此相當於-r 參數。
    9.  -E, --extended-regexp
       采用規則表示式去解釋樣式。
      
   10.  -e PATTERN, --regexp=PATTERN
       把樣式做為一個partern,通常用在避免partern用-開始。   
   11.  -f FILE, --file=FILE
       事先將要搜尋的樣式寫入到一個檔案,一行一個樣式。
       然后采用檔案搜尋。
       空的檔案表示沒有要搜尋的樣式,因此也就不會有任何符合。
        
   ex: (newfile為搜尋樣式檔)
       $grep -f newfile file     
   12.  -G, --basic-regexp
       將樣式視為基本的規則表示式解釋。(此為預設)
   13.  -H, --with-filename
       在每個符合樣式行前加上符合的檔案名稱,若有路徑會顯示路徑。
        
   ex: (在file與testfile中搜尋panda樣式)   
       $grep -H panda file ./testfile
                file:panda
                ./testfile:panda
                $
      
   14.  -h, --no-filename   
        與-H參數相類似,但在輸出時不顯示路徑。
   15.  --help  
        產生簡短的help訊息。
   16.  -I
        grep會強制認為此二進位檔案沒有包含任何搜尋樣式,
        與--binary-files=without-match參數相同。
        ex:  $ grep -I  panda mv
   17.  -i, --ignore-case        
        忽略大小寫,包含要搜尋的樣式及被搜尋的檔案。
               
        ex:  $ grep -i panda mv
                 
   18.  -L, --files-without-match  
        不顯示平常一般的輸出結果,反而顯示出沒有符合的檔案名稱。
   19.  -l, --files-with-matches               
        不顯示平常一般的輸出結果,只顯示符合的檔案名稱。
   20.  --mmap               
         如果可能,使用mmap系統呼叫去讀取輸入,而不是預設的read系統呼叫。  
         在某些狀況,--mmap 能產生較好的效能。 然而,--mmap  
         如果運作中檔案縮短,或I/O 錯誤發生時,
         可能造成未定義的行為(包含core dump),。
               
   21.  -n, --line-number
         在顯示行前,標上行號。
               
         ex:  $ grep -n  panda file   
                顯示結果相似於下:
                行號:符合行的內容
   22.  -q, --quiet, --silent  
        不顯示任何的一般輸出。請參閱-s或--no-messages
   23.  -r, --recursive
      
        遞地,讀取每個資料夾下的所有檔案,此相當於 -d recsuse 參數。
   24.  -s, --no-messages
       不顯示關於不存在或無法讀取的錯誤訊息。
      
       小: 不像GNU grep,傳統的grep不符合POSIX.2協定,
       因為缺乏-q參數,且他的-s 參數表現像GNU grep的 -q 參數。
       Shell Script傾向將傳統的grep移植,避開-q及-s參數,
       且將輸出限制到/dev/null。
     
       POSIX: 定義UNIX及UNIX-like系統需要提供的功能。               
     
   25.  -V, --version
        顯示出grep的版本號到標準錯誤。
        當您在回報有關grep的bugs時,grep版本號是必須要包含在內的。
   26.  -v, --invert-match
        顯示除搜尋樣式行之外的全部。
                    
   27.  -w, --word-regexp
        將搜尋樣式視為一個字去搜尋,完全符合該"字"的行才會被列出。
   28.  -x, --line-regexp
        將搜尋樣式視為一行去搜尋,完全符合該"行"的行才會被列出。

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久99精品国产 | 综合一区二区三区 | 秋霞电影一区二区 | 中文字幕视频免费 | 日本手机在线 | 日本三级全黄三级a | 色吊丝2288sds中文字幕 | 日本黄色高清视频 | 狠狠色综合欧美激情 | 久久久久久国产精品久久 | 国产成人在线一区二区 | 91av视频在线免费观看 | 中文字幕一区二区三区四区 | 精品国产一区二区三区久久影院 | 在线播放第一页 | 91九色视频 | av黄色免费| 亚洲a一区 | 丝袜毛片| 自拍偷拍第一页 | 国产香蕉视频在线播放 | 午夜影视大全 | 视频一区在线观看 | 亚洲一区三区在线观看 | 青青青伊人 | 亚洲+变态+欧美+另类+精品 | 成人小视频在线 | 欧美日韩一区二区三区四区 | www.887色视频免费 | 欧美九九 | 色偷偷人人澡人人爽人人模 | 国产在线观看网站 | 国产不卡一区在线观看 | 国产成人综合在线 | 亚洲国产高清高潮精品美女 | 欧洲亚洲一区二区三区 | 黑人精品欧美一区二区蜜桃 | 亚洲综合中文字幕在线观看 | 色婷婷av一区二区三区软件 | 久久狠狠 | 亚洲成人福利视频 |