亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發(fā) > Linux Shell > 正文

awk基礎(chǔ)知識小結(jié)第1/2頁

2020-07-27 19:24:43
字體:
供稿:網(wǎng)友

1、使用規(guī)則

awk 適合于文本處理和報表生成,它還有許多精心設(shè)計的特性,允許進(jìn)行需要特殊技巧程序設(shè)計。
awk 的語法較為常見。它借鑒了某些語言的一些精華部分,如C 語言、python 和 bash。

第一個 awk
讓我們繼續(xù),開始使用 awk,以了解其工作原理。在命令行中輸入以下命令:
$ awk '{ print }' /etc/passwd
您將會見到 /etc/passwd 文件的內(nèi)容出現(xiàn)在眼前。現(xiàn)在,解釋 awk 做了些什么。調(diào)用 awk 時,我們指定 /etc/passwd 作為輸入文件。執(zhí)行 awk 時,它依次對 /etc/passwd 中的每一行執(zhí)行 print 命令。所有輸出都發(fā)送到 stdout,所得到的結(jié)果與與執(zhí)行catting /etc/passwd完全相同。

現(xiàn)在,解釋 { print } 代碼塊。在 awk 中,花括號用于將幾塊代碼組合到一起,這一點類似于 C 語言。在代碼塊中只有一條 print 命令。在 awk 中,如果只出現(xiàn) print 命令,那么將打印當(dāng)前行的全部內(nèi)容。

這里是另一個awk 示例,作用與上例完全相同:
$ awk '{ print $0 }' /etc/passwd

在 awk 中,$0 變量表示整個當(dāng)前行,所以 print 和 print $0 的作用完全一樣。

創(chuàng)建一個 awk 程序,讓它輸出與輸入數(shù)據(jù)完全無關(guān)的數(shù)據(jù)。
示例1:
$ awk '{ print "" }' /etc/passwd
只要將 "" 字符串傳遞給 print 命令,它就會打印空白行。測試該腳本,將會發(fā)現(xiàn)對于/etc/passwd文件中的每一行,awk 都輸出一個空白行。由此可知,awk對輸入文件中的每一行都執(zhí)行這個腳本。

示例2:
$ awk '{ print "hiya" }' /etc/passwd
運行此腳本將在您的屏幕上寫滿 hiya。

2、處理多個字段
awk 非常善于處理分成多個邏輯字段的文本,還可以引用 awk 腳本中每個獨立的字段。
打印系統(tǒng)上所有用戶帳戶的列表:
$ awk -F":" '{ print $1 }' /etc/passwd
上例中,調(diào)用awk時,使用 -F 選項來指定 ":" 作為字段分隔符。awk 處理 print $1 命令時,它會打印出在輸入文件中每一行中出現(xiàn)的第一個字段。
以下是另一示例:
$ awk -F":" '{ print $1 $3 }' /etc/passwd

以下是該腳本輸出的摘錄:
halt7
operator11
root0
shutdown6
sync5
bin1
....etc.

如您所見,awk 打印出 /etc/passwd 文件的第一和第三個字段,它們正好分別是用戶名和用戶標(biāo)識字段。現(xiàn)在,當(dāng)腳本運行時,它并不理想--在兩個輸出字段之間沒有空格!如果習(xí)慣于使用 bash 或 python 進(jìn)行編程,那么您會指望 print $1 $3 命令在兩個字段之間插入空格。然而,當(dāng)兩個字符串在 awk 程序中彼此相鄰時,awk 會連接它們但不在它們之間添加空格。以下命令會在這兩個字段中插入空格:
$ awk -F":" '{ print $1 " " $3 }' /etc/passwd

以這種方式調(diào)用 print 時,它將連接 $1、" " 和 $3,創(chuàng)建可讀的輸出。
還可以插入一些文本標(biāo)簽:
$ awk -F":" '{ print "username: " $1 "ttuid:" $3" }' /etc/passwd

這將產(chǎn)生以下輸出:
username: halt          uid:7
username: operator      uid:11
username: root          uid:0
username: shutdown      uid:6
username: sync          uid:5
username: bin           uid:1
....etc.

3、調(diào)用外部腳本
將腳本作為命令行自變量傳遞給awk對于小的單行程序來說很簡單。
而對于多行程序,則可以在外部文件中撰寫腳本,然后向awk傳遞-f選項,以向它提供外部腳本文件的調(diào)用:
$ awk -f myscript.awk myfile.in

將腳本放入文本文件還可以使用附加awk功能。例如:
BEGIN {
      FS=":"
}
{ print $1 }
打印出 /etc/passwd 中每一行的第一個字段

在這個腳本中,字段分隔符在代碼自身中指定(通過設(shè)置 FS 變量)。
在腳本自身中設(shè)置字段分隔符,可以少輸入一個命令行自變量。

4、begin和end塊

BEGIN 和 END 塊
通常,對于每個輸入行,awk 都會執(zhí)行每個腳本代碼塊一次。然而,可能需要在 awk 開始處理輸入文件中的文本之前執(zhí)行初始化代碼。對于這種情況,awk 允許您定義一個 BEGIN 塊。我們在前一個示例中使用了 BEGIN 塊。因為 awk 在開始處理輸入文件之前會執(zhí)行 BEGIN 塊,因此它是初始化 FS(字段分隔符)變量、打印頁眉或初始化其它在程序中以后會引用的全局變量的極佳位置。

awk 還提供了另一個特殊塊,叫作 END 塊。awk 在處理了輸入文件中的所有行之后執(zhí)行這個塊。通常,END 塊用于執(zhí)行最終計算或打印應(yīng)該出現(xiàn)在輸出流結(jié)尾的摘要信息。

5、正則表達(dá)式
awk 允許使用正則表達(dá)式,根據(jù)正則表達(dá)式是否匹配當(dāng)前行來選擇執(zhí)行獨立代碼塊。
輸出包含字符序列foo的行:
/foo/ { print }

復(fù)雜點的,只打印包含浮點數(shù)的行:
/[0-9]+.[0-9]*/ { print }

可以將任意一種布爾表達(dá)式放在一個代碼塊之前,以控制何時執(zhí)行某特定塊。僅當(dāng)對前面的布爾表達(dá)式求值為真時,awk 才執(zhí)行代碼塊。以下示例腳本輸出將輸出其第一個字段等于 fred 的所有行中的第三個字段。如果當(dāng)前行的第一個字段不等于 fred,awk 將繼續(xù)處理文件而不對當(dāng)前行執(zhí)行 print 語句:
$1 == "fred" { print $3 }

awk 提供了完整的比較運算符集合,包括 "=="、"<"、">"、"<="、">=" 和 "!="。另外,awk 還提供了 "~" 和 "!~" 運算符,它們分別表示“匹配”和“不匹配”。
它們的用法是在運算符左邊指定變量,在右邊指定正則表達(dá)式。如果某一行的第五個字段包含字符序列 root,以下示例只打印這一行中的第三個字段:
$5 ~ /root/ { print $3 }

6、條件語句
awk 還提供了非常好的類似于 C 語言的 if 語句。if 語句示例:
{
    if ( $5 ~ /root/ ) {
       print $3
    }
}
對每一個輸入行執(zhí)行代碼塊,使用 if 語句來選擇執(zhí)行 print 命令。
更復(fù)雜的 awk if 語句示例。
{
    if ( $1 == "foo" ) {
       if ( $2 == "foo" ) {
            print "uno"
        } else {
          print "one"
        }
          } else if ($1 == "bar" ) {
                    print "two"
                 } else {
                    print "three"
                 }
}

使用 if 語句還可以將代碼:
! /matchme/ { print $1 $3 $4 }
轉(zhuǎn)換成:
{
     if ( $0 !~ /matchme/ ) {
         print $1 $3 $4
     }
}
這兩個腳本都只輸出不包含 matchme 字符序列的那些行。

awk 還允許使用布爾運算符 "||"(邏輯與)和 "&&"(邏輯或),以便創(chuàng)建更復(fù)雜的布爾表達(dá)式:
( $1 == "foo" ) && ( $2 == "bar" ) { print }
這個示例只打印第一個字段等于 foo 且第二個字段等于 bar 的行。

7、變量
awk的變量,數(shù)值變量與字符串變量。

數(shù)值變量
至今,我們不是打印字符串、整行就是特定字段。然而,awk還可以執(zhí)行整數(shù)和浮點運算。使用數(shù)學(xué)表達(dá)式,可以很方便地編寫計算文件中空白行數(shù)量的腳本。
BEGIN   { x=0 }
/^$/    { x=x+1 }
END     { print "I found " x " blank lines. :}" }
在 BEGIN 塊中,將整數(shù)變量 x 初始化成零。然后,awk 每次遇到空白行時,awk 將執(zhí)行 x=x+1 語句,遞增 x。
處理完所有行之后,執(zhí)行 END 塊,awk 將打印出最終摘要,指出它找到的空白行數(shù)量。

字符串化變量
awk 的優(yōu)點之一就是“簡單和字符串化”。我認(rèn)為 awk 變量“字符串化”是因為所有 awk 變量在內(nèi)部都是按字符串形式存儲的。同時,awk 變量是“簡單的”,因為可以對它執(zhí)行數(shù)學(xué)操作,且只要變量包含有效數(shù)字字符串,awk 會自動處理字符串到數(shù)字的轉(zhuǎn)換步驟。要理解我的觀點,請研究以下示例:
x="1.01"
# We just set x to contain the *string* "1.01"
x=x+1
# We just added one to a *string*
print x
# Incidentally, these are comments :)
awk 將輸出:
2.01

雖然將字符串值 1.01 賦值給變量 x,仍然可以對它加一。但在 bash 和 python 中卻不能這樣做。
首先,bash 不支持浮點運算。而且,如果 bash 有“字符串化”變量,它們并不“簡單”;要執(zhí)行任何數(shù)學(xué)操作,bash 要求我們將數(shù)字放到丑陋的 $( ) ) 結(jié)構(gòu)中。
如果使用 python,則必須在對 1.01 字符串執(zhí)行任何數(shù)學(xué)運算之前,將它轉(zhuǎn)換成浮點值。雖然這并不困難,但它仍是附加的步驟。
如果使用 awk,它是全自動的,而那會使我們的代碼又好又整潔。如果想要對每個輸入行的第一個字段乘方并加一,可以使用以下腳本:
{ print ($1^2)+1 }

如果做一個小實驗,就可以發(fā)現(xiàn)如果某個特定變量不包含有效數(shù)字,awk 在對數(shù)學(xué)表達(dá)式求值時會將該變量當(dāng)作數(shù)字零處理。

8、運算符
awk 有完整的數(shù)學(xué)運算符集合。除了標(biāo)準(zhǔn)的加、減、乘、除,awk 還允許使用前面演示過的指數(shù)運算符 "^"、模(余數(shù))運算符 "%" 和其它許多從 C 語言中借入的易于使用的賦值操作符。

這些運算符包括前后加減(i++、--foo)、加/減/乘/除賦值運算符( a+=3、b*=2、c/=2.2、d-=6.2)。不僅如此 -- 我們還有易于使用的模/指數(shù)賦值運算符(a^=2、b%=4)。

字段分隔符
awk 有它自己的特殊變量集合。其中一些允許調(diào)整 awk 的運行方式,而其它變量可以被讀取以收集關(guān)于輸入的有用信息。我們已經(jīng)接觸過這些特殊變量中的一個,F(xiàn)S。前面已經(jīng)提到過,這個變量讓您可以設(shè)置 awk 要查找的字段之間的字符序列。我們使用 /etc/passwd 作為輸入時,將 FS 設(shè)置成 ":"。當(dāng)這樣做有問題時,我們還可以更靈活地使用 FS。

FS 值并沒有被限制為單一字符;可以通過指定任意長度的字符模式,將它設(shè)置成規(guī)則表達(dá)式。如果正在處理由一個或多個 tab 分隔的字段,您可能希望按以下方式設(shè)置 FS:
FS="t+"

以上示例中,我們使用特殊 "+" 規(guī)則表達(dá)式字符,它表示“一個或多個前一字符”。

如果字段由空格分隔(一個或多個空格或 tab),您可能想要將 FS 設(shè)置成以下規(guī)則表達(dá)式:
FS="[[:space:]+]"

這個賦值表達(dá)式也有問題,它并非必要。為什么?因為缺省情況下,F(xiàn)S 設(shè)置成單一空格字符,awk 將這解釋成表示“一個或多個空格或 tab”。在這個特殊示例中,缺省 FS 設(shè)置恰恰是您最想要的!

復(fù)雜的規(guī)則表達(dá)式也不成問題。即使您的記錄由單詞 "foo" 分隔,后面跟著三個數(shù)字,以下規(guī)則表達(dá)式仍允許對數(shù)據(jù)進(jìn)行正確的分析:

FS="foo[0-9][0-9][0-9]"

字段數(shù)量
接著我們要討論的兩個變量通常并不是需要賦值的,而是用來讀取以獲取關(guān)于輸入的有用信息。第一個是 NF 變量,也叫做“字段數(shù)量”變量。awk 會自動將該變量設(shè)置成當(dāng)前記錄中的字段數(shù)量??梢允褂?NF 變量來只顯示某些輸入行:
NF == 3 { print "this particular record has three fields: " $0 }
當(dāng)然,也可以在條件語句中使用 NF 變量,如下:
{  
    if ( NF > 2 ) {
       print $1 " " $2 ":" $3
    }
}

9、處理記錄
記錄號
記錄號 (NR) 是另一個方便的變量。它始終包含當(dāng)前記錄的編號(awk 將第一個記錄算作記錄號 1)。迄今為止,我們已經(jīng)處理了每一行包含一個記錄的輸入文件。對于這些情況,NR 還會告訴您當(dāng)前行號。然而,當(dāng)我們在本系列以后部分中開始處理多行記錄時,就不會再有這種情況,所以要注意!可以象使用 NF 變量一樣使用 NR 來只打印某些輸入行:
(NR < 10 ) || (NR > 100) { print "We are on record number 1-9 or 101+" }
另一個示例:
{
   #skip header
   if (NR>10) {
       print "ok, now for the real information!"
   }

}

awk 提供了適合各種用途的附加變量。我們將在以后的文章中討論這些變量。

多行記錄
awk 是一種用于讀取和處理結(jié)構(gòu)化數(shù)據(jù)(如系統(tǒng)的 /etc/passwd 文件)的極佳工具。/etc/passwd 是 UNIX 用戶數(shù)據(jù)庫,并且是用冒號定界的文本文件,它包含許多重要信息,包括所有現(xiàn)有用戶帳戶和用戶標(biāo)識,以及其它信息。在我的前一篇文章中,我演示了 awk 如何輕松地分析這個文件。我們只須將 FS(字段分隔符)變量設(shè)置成 ":"。

正確設(shè)置了 FS 變量之后,就可以將 awk 配置成分析幾乎任何類型的結(jié)構(gòu)化數(shù)據(jù),只要這些數(shù)據(jù)是每行一個記錄。然而,如果要分析占據(jù)多行的記錄,僅僅依靠設(shè)置 FS 是不夠的。在這些情況下,我們還需要修改 RS 記錄分隔符變量。RS 變量告訴 awk 當(dāng)前記錄什么時候結(jié)束,新記錄什么時候開始。

譬如,讓我們討論一下如何完成處理“聯(lián)邦證人保護(hù)計劃”所涉及人員的地址列表的任務(wù):
Jimmy the Weasel
100 Pleasant Drive
San Francisco, CA 12345
Big Tony
200 Incognito Ave.
Suburbia, WA 67890

理論上,我們希望 awk 將每 3 行看作是一個獨立的記錄,而不是三個獨立的記錄。如果 awk 將地址的第一行看作是第一個字段 ($1),街道地址看作是第二個字段 ($2),城市、州和郵政編碼看作是第三個字段 $3,那么這個代碼就會變得很簡單。代碼如下:
BEGIN {
  FS="n"
  RS=""
}

在上面這段代碼中,將 FS 設(shè)置成 "n" 告訴 awk 每個字段都占據(jù)一行。通過將 RS 設(shè)置成 "",還會告訴 awk 每個地址記錄都由空白行分隔。一旦 awk 知道是如何格式化輸入的,它就可以為我們執(zhí)行所有分析工作,腳本的其余部分很簡單。讓我們研究一個完整的腳本,它將分析這個地址列表,并將每個記錄打印在一行上,用逗號分隔每個字段。
address.awk BEGIN {
   FS="n"
   RS=""
}
{
  print $1 ", " $2 ", " $3
}

將腳本保存為 address.awk,地址數(shù)據(jù)存儲在文件 address.txt 中,可以通過輸入 "awk -f address.awk address.txt" 執(zhí)行此腳本。輸出如下:
Jimmy the Weasel, 100 Pleasant Drive, San Francisco, CA 12345
Big Tony, 200 Incognito Ave., Suburbia, WA 67890

OFS 和 ORS
在 address.awk 的 print 語句中,可以看到 awk 會連接(合并)一行中彼此相鄰的字符串。我們使用此功能在同一行上的三個字段之間插入一個逗號和空格 (", ")。這個方法雖然有用,但比較難看。與其在字段間插入 ", " 字符串,倒不如讓通過設(shè)置一個特殊 awk 變量 OFS,讓 awk 完成這件事。
print "Hello", "there", "Jim!"

這行代碼中的逗號并不是實際文字字符串的一部分。事實上,它們告訴 awk "Hello"、"there" 和 "Jim!" 是單獨的字段,并且應(yīng)該在每個字符串之間打印 OFS 變量。
缺省情況下,awk 產(chǎn)生以下輸出:
Hello there Jim!

這是缺省情況下的輸出結(jié)果,OFS 被設(shè)置成 " ",單個空格。不過,我們可以方便地重新定義 OFS,這樣 awk 將插入我們中意的字段分隔符。以下是原始 address.awk 程序的修訂版,它使用 OFS 來輸出那些中間的 ", " 字符串:

address.awk 的修訂版
BEGIN {
     FS="n"
     RS=""
    OFS=", "
}
{
    print $1, $2, $3
}
 awk 還有一個特殊變量 ORS,全稱是“輸出記錄分隔符”。通過設(shè)置缺省為換行 ("n") 的 OFS,我們可以控制在 print 語句結(jié)尾自動打印的字符。缺省 ORS 值會使 awk 在新行中輸出每個新的 print 語句。如果想使輸出的間隔翻倍,可以將 ORS 設(shè)置成 "nn"?;蛘撸绻胍脝蝹€空格分隔記錄(而不換行),將 ORS 設(shè)置成 " "。

將多行轉(zhuǎn)換成用 tab 分隔的格式
假設(shè)我們編寫了一個腳本,它將地址列表轉(zhuǎn)換成每個記錄一行,且用 tab 定界的格式,以便導(dǎo)入電子表格。使用稍加修改的 address.awk 之后,就可以清楚地看到這個程序只適合于三行的地址。如果 awk 遇到以下地址,將丟掉第四行,并且不打印該行:
Cousin Vinnie
Vinnie's Auto Shop
300 City Alley
Sosueme, OR 76543

要處理這種情況,代碼最好考慮每個字段的記錄數(shù)量,并依次打印每個記錄。現(xiàn)在,代碼只打印地址的前三個字段。以下就是我們想要的一些代碼:

適合具有任意多字段的地址的 address.awk 版本
BEGIN {
  FS="n"
  RS=""
  ORS=""
}
 { 
 x=1
 while ( x<NF ) {
 print $x "t"
 x++
  }
print $NF "n"
}

首先,將字段分隔符 FS 設(shè)置成 "n",將記錄分隔符 RS 設(shè)置成 "",這樣 awk 可以象以前一樣正確分析多行地址。然后,將輸出記錄分隔符 ORS 設(shè)置成 "",它將使 print 語句在每個調(diào)用結(jié)尾不輸出新行。這意味著如果希望任何文本從新的一行開始,那么需要明確寫入 print "n"。

在主代碼塊中,創(chuàng)建了一個變量 x 來存儲正在處理的當(dāng)前字段的編號。起初,它被設(shè)置成 1。然后,我們使用 while 循環(huán)(一種 awk 循環(huán)結(jié)構(gòu),等同于 C 語言中的 while 循環(huán)),對于所有記錄(最后一個記錄除外)重復(fù)打印記錄和 tab 字符。最后,打印最后一個記錄和換行;此外,由于將 ORS 設(shè)置成 "",print 將不輸出換行。程序輸出如下,這正是我們所期望的(不算漂亮,但用 tab 定界,以便于導(dǎo)入電子表格):
Jimmy the Weasel        100 Pleasant Drive      San Francisco, CA 12345
Big Tony        200 Incognito Ave.      Suburbia, WA 67890
Cousin Vinnie   Vinnie's Auto Shop      300 City Alley  Sosueme, OR 76543


12下一頁閱讀全文
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产乱肥老妇国产一区二| 精品影片一区二区入口| 蜜臀久久精品久久久用户群体| 美女视频网站久久| 国产一级黄色录像片| 国产丝袜一区二区| 高潮无码精品色欲av午夜福利| 性折磨bdsm欧美激情另类| 日本在线不卡视频| 国产一区美女| 国产另类第一区| 西西人体一区二区| 午夜免费福利在线观看| a级免费观看| 亚洲色图美女| 午夜影院网站| 粉嫩av一区二区三区免费观看| 九色porny丨入口在线| 北条麻妃在线视频| 欧美一级专区| 久久人人爽人人爽人人片av不| 麻豆免费在线视频| av电影在线观看一区二区三区| 久久69精品久久久久久国产越南| 国产一在线精品一区在线观看| 国产网站观看9久| 国产综合精品在线| 精品一区二区三区四区五区| 理论片午午伦夜理片在线播放| 91精品国自产在线| 高清在线视频不卡| 热久久精品免费视频| 狠狠色噜噜狠狠狠888奇米| 美女扒开腿让男人桶爽久久动漫| 在线观看视频一区二区三区| 中文字幕在线综合| www日本在线观看| 91麻豆国产自产在线观看亚洲| 人人香蕉久久| 成人欧美一区二区三区视频| 国产手机精品视频| 日本天堂在线| 免费看a级黄色片| 人妻换人妻a片爽麻豆| 欧性猛交ⅹxxx乱大交| 色94色欧美sute亚洲线路一ni| 亚洲av无码精品一区二区| 高清国产午夜精品久久久久久| 亚洲一区二区三区精品中文字幕| 销魂美女一区二区三区视频在线| 日韩成人激情在线| 中文区中文字幕免费看| 日韩亚洲综合在线| 日韩av一二三四区| 欧美电影完整版在线观看| 日韩免费av| 国产h片在线观看| 香蕉久久夜色精品国产更新时间| 国内精品卡一卡二卡三新区| 日韩精品一区二区三区老鸭窝| 中文字幕一区三区| 黄色日韩精品| 国产宾馆自拍| 成年片费网站色大全免费视频| 不卡在线视频中文字幕| 9999热视频| 欧美丝袜激情| 欧美日韩电影免费看| 精品这里只有精品| 男女做爰猛烈刺激| 亚洲精品福利在线观看| 欧美在线亚洲在线| 日韩免费在线播放| 午夜精品视频一区二区三区在线看| 久久看片网站| 国产精品一品视频| 台湾色综合娱乐中文网| 一个人看的www免费观看视频| 四虎成人欧美精品在永久在线| 色先锋aa成人| 国产成人h网站| 一区二区三区美女视频| 人妻中文字幕一区二区三区| 日本成人一区二区三区| 国产精品国产三级国产普通话三级| 公交车上扒开嫩j挺进去| av在线三区| 日韩黄色大片| 99精品视频免费在线观看| 99热99精品| 久久成人av少妇免费| 亚洲精品喷潮一区二区三区| 99亚洲精品视频| 久久96国产精品久久99软件| 99热精品在线| 日本精品一二三区| 成人免费视频一区| 日韩欧美一区二区视频在线播放| 欧美在线 | 亚洲| 国产免费一区二区三区四区| 欧洲美女亚洲激情| 熟女高潮一区二区三区| 大陆极品少妇内射aaaaaa| 国产欧美va欧美不卡在线| 加勒比婷婷色综合久久| 国产日韩精品中文字无码| 高清视频欧美一级| 97精品国产91久久久久久| 松下纱荣子在线观看| 日韩亚洲欧美中文三级| 2020日本不卡一区二区视频| 蜜臀av午夜精品久久| 黄色三级网站在线观看| bdsm精品捆绑chinese女| 国产欧美日韩免费看aⅴ视频| 狠狠色丁香婷婷综合久久片| 91丝袜一区二区三区| 女同久久另类99精品国产| 日本三级中文字幕在线观看| 欧美毛片又粗又长又大| 日韩簧片在线观看| 夜夜操 天天摸| 韩国日本不卡在线| 成人做爰视频www网站小优视频| 97国产视频| 奇米4444一区二区三区| 最新中文字幕2018| 香港伦理在线| 91影视免费在线观看| 日韩**一区毛片| 女生裸体免费视频| 欧美日韩国产亚洲沙发| 国产有码一区二区| 日本欧美在线看| 噜噜噜天天躁狠狠躁夜夜精品| 亚洲精品丝袜日韩| 国产91在线播放精品91| 国产精品99久久久久久动医院| 国产免费不卡| 欧美三级午夜理伦三级| 日本国产在线视频| 美女午夜精品| 潘金莲激情呻吟欲求不满视频| 欧美专区日韩视频| 91热门视频在线观看| 超碰精品在线观看| 国产情侣小视频| 国内综合精品午夜久久资源| 国产精品免费一区二区| 国产不卡在线一区| 成人影院av| 擼擼色在线看观看免费| 日韩aⅴ视频一区二区三区| 成人美女在线观看| 亚洲高清视频免费观看| 一区二区三区精品久久久| 欧美国产日韩一区二区| 3344国产精品免费看| h在线观看视频| 亚洲欧洲一区二区三区久久| 欧美成aaa人片在线观看蜜臀| 可以直接看的无码av| 黄色精品视频网站| 日本高清不卡码| 最新国产在线视频| 国模视频一区二区三区| 美女性感视频久久| 精品一区二区三区四区五区六区| 99麻豆久久久国产精品免费| 成人性生交大片免费看中文网站| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 欧美精品xxxxx| 91超碰在线电影| 欧美精品大片| 久久久综合激的五月天| 丁香色欲久久久久久综合网| 午夜免费福利网站| 91黄色在线| 精品视频亚洲| 久久久久北条麻妃免费看| 丰满少妇又爽又紧又丰满电影| 裸体丰满少妇做受久久99精品| 日韩成人免费在线视频| 超碰中文字幕在线| 精品欧美一区免费观看α√| 欧美性20hd另类| 久久久免费av| 日本午夜精品视频| 污污视频在线免费| 日本网站在线播放| 亚洲影院在线观看| 网曝门事件国产精品二区| 91免费看国产| 综合久久久久| 午夜久久久精品| 无码av免费精品一区二区三区| 欧美重口另类videos人妖| 中字幕一区二区三区乱码| 秋霞在线观看av| 中文字幕人妻一区| 欧美久久久久久久久| 手机在线一区二区三区| 亚洲专区在线播放| 日韩少妇内射免费播放| av电影高清在线观看| 久久草在线看| 美国毛片一区二区三区| 九九综合在线| 亚洲av综合色区无码一二三区| 国产免费高清av| 欧美一级做性受免费大片免费| 亚洲激情 欧美| 一区二区三区视频在线看| 黑巨人与欧美精品一区| 欧美xxxx黑人又粗又长精品| 亚洲av无码国产综合专区| 日韩三级在线免费观看| 日韩欧美专区在线| 中文av免费观看| 91高清在线| 色综合久久88色综合天天提莫| 欧美中日韩免费视频| 高清不卡日本v二区在线| 国产精品jvid在线观看蜜臀| 色播一区二区| 91精品国产一区二区三区蜜臀| 国产精品jizz在线观看美国| 欧美日韩破处| 美女在线免费视频| 国产自产精品| 老女人av在线| 亚洲第一第二区| 激情视频免费网站| 性做久久久久久久免费看| 国产高清自产拍av在线| 久久久久久久久久久久久女国产乱| 懂色av中文字幕一区二区三区| 美女又爽又黄免费动漫| 日韩有码中文字幕在线| 欧美成人精品在线观看| eeuss免费天堂影院| 国产a∨精品一区二区三区不卡| 午夜影院免费在线| 精品亚洲免费视频| 99久久精品情趣| 在线观看日韩片| 亚洲另类春色校园小说| 成人看片在线观看| 狠狠v欧美ⅴ日韩v亚洲v大胸| jizzjizzjizz中国| 希岛爱理中文字幕| 综合在线影院| fc2成人免费视频| 国产成人手机高清在线观看网站| 国产一区二区三区黄片| 欧美精品少妇一区二区三区| 日本三级在线播放完整版| 国产麻豆日韩欧美久久| 久草视频手机在线| jizzjizzjizz在线观看| jizzzz日本| 成人中文视频| 欧美成人亚洲高清在线观看| 欧美一区二区三区四区高清| 女仆av观看一区| 国产寡妇树林野战在线播放| 国产大奶视频| 久久这里只有精品首页| av在线不卡一区| 国产日韩欧美视频在线观看| 中文字幕在线看高清电影| 免费观看一区二区三区毛片| 亚洲精品国产suv一区88| 亚洲激情一区| 亚洲免费在线观看视频| 日本黄网免费一区二区精品| 女同性αv亚洲女同志| 在线国产一区二区三区| 久久久久久成人精品| 国产精品国产自产拍高清av| 人妻精品久久久久中文字幕69| 国产精品污污网站在线观看| jizz.日本| 成视频免费观看在线看| 国产成人精品网址| 国产精品s色| 精品一区二区三区影院在线午夜| 男女爱爱免费网站| 色婷婷av在线| 国产美女一区二区三区| 久久人体做爰大胆| 久久精品美女视频网站| 日日爱66.cn| 亚洲国产中文字幕在线视频综合| 综合免费一区二区三区| 黑人乱码一区二区三区av| 免费一级做a爰片久久毛片潮| 全部毛片永久免费看| 1024亚洲合集| 久久久久国产精品午夜一区| 久久这里只有精品9| 电影一区二区| 91天堂在线视频| 国产精品全国免费观看高清| 成人av资源| fc2ppv素人在线| 国产精品宾馆在线精品酒店| 成人福利资源| 成人免费黄色在线| 色综合天天做天天爱| 亚洲 欧美 日韩在线| 神马午夜dy888| 国色天香2019中文字幕在线观看| 韩日在线播放| 欧美成人vr18sexvr| 精品视频在线播放一区二区三区| 欧美成人aaa片一区国产精品| 欧美成人亚洲| 手机在线免费看片| 香蕉视频污视频| 国产精品一区二区性色av| 91美女主播在线视频| 亚洲国产精品区| 一区二区国产视频| 亚洲色欲色欲www| 国产99一区视频免费| 国产一区二区三区高清播放| 亚洲国产另类av|