校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > awk基礎知識小結第1/2頁

awk基礎知識小結第1/2頁

熱門標簽:昆明電話外呼系統好么 外呼系統一天耗費多少流量 衡水外呼線路解決 艾比利外呼系統 陜西便宜電銷機器人軟件 海口智能語音電銷機器人好用嗎 杞縣地圖標注app 免費門店地圖標注注冊入駐 電話機器人每天搜索多少次

1、使用規則

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

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

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

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

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

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

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

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

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

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

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

這將產生以下輸出:
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、調用外部腳本
將腳本作為命令行自變量傳遞給awk對于小的單行程序來說很簡單。
而對于多行程序,則可以在外部文件中撰寫腳本,然后向awk傳遞-f選項,以向它提供外部腳本文件的調用:
$ awk -f myscript.awk myfile.in

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

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

4、begin和end塊

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

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

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

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

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

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

6、條件語句
awk 還提供了非常好的類似于 C 語言的 if 語句。if 語句示例:
{
    if ( $5 ~ /root/ ) {
       print $3
    }
}
對每一個輸入行執行代碼塊,使用 if 語句來選擇執行 print 命令。
更復雜的 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 }
轉換成:
{
     if ( $0 !~ /matchme/ ) {
         print $1 $3 $4
     }
}
這兩個腳本都只輸出不包含 matchme 字符序列的那些行。

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

7、變量
awk的變量,數值變量與字符串變量。

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

字符串化變量
awk 的優點之一就是“簡單和字符串化”。我認為 awk 變量“字符串化”是因為所有 awk 變量在內部都是按字符串形式存儲的。同時,awk 變量是“簡單的”,因為可以對它執行數學操作,且只要變量包含有效數字字符串,awk 會自動處理字符串到數字的轉換步驟。要理解我的觀點,請研究以下示例:
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 有“字符串化”變量,它們并不“簡單”;要執行任何數學操作,bash 要求我們將數字放到丑陋的 $( ) ) 結構中。
如果使用 python,則必須在對 1.01 字符串執行任何數學運算之前,將它轉換成浮點值。雖然這并不困難,但它仍是附加的步驟。
如果使用 awk,它是全自動的,而那會使我們的代碼又好又整潔。如果想要對每個輸入行的第一個字段乘方并加一,可以使用以下腳本:
{ print ($1^2)+1 }

如果做一個小實驗,就可以發現如果某個特定變量不包含有效數字,awk 在對數學表達式求值時會將該變量當作數字零處理。

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

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

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

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

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

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

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

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

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

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

9、處理記錄
記錄號
記錄號 (NR) 是另一個方便的變量。它始終包含當前記錄的編號(awk 將第一個記錄算作記錄號 1)。迄今為止,我們已經處理了每一行包含一個記錄的輸入文件。對于這些情況,NR 還會告訴您當前行號。然而,當我們在本系列以后部分中開始處理多行記錄時,就不會再有這種情況,所以要注意!可以象使用 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 是一種用于讀取和處理結構化數據(如系統的 /etc/passwd 文件)的極佳工具。/etc/passwd 是 UNIX 用戶數據庫,并且是用冒號定界的文本文件,它包含許多重要信息,包括所有現有用戶帳戶和用戶標識,以及其它信息。在我的前一篇文章中,我演示了 awk 如何輕松地分析這個文件。我們只須將 FS(字段分隔符)變量設置成 ":"。

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

譬如,讓我們討論一下如何完成處理“聯邦證人保護計劃”所涉及人員的地址列表的任務:
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 設置成 "n" 告訴 awk 每個字段都占據一行。通過將 RS 設置成 "",還會告訴 awk 每個地址記錄都由空白行分隔。一旦 awk 知道是如何格式化輸入的,它就可以為我們執行所有分析工作,腳本的其余部分很簡單。讓我們研究一個完整的腳本,它將分析這個地址列表,并將每個記錄打印在一行上,用逗號分隔每個字段。
address.awk BEGIN {
   FS="n"
   RS=""
}
{
  print $1 ", " $2 ", " $3
}

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

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

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

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

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

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

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

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

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

在主代碼塊中,創建了一個變量 x 來存儲正在處理的當前字段的編號。起初,它被設置成 1。然后,我們使用 while 循環(一種 awk 循環結構,等同于 C 語言中的 while 循環),對于所有記錄(最后一個記錄除外)重復打印記錄和 tab 字符。最后,打印最后一個記錄和換行;此外,由于將 ORS 設置成 "",print 將不輸出換行。程序輸出如下,這正是我們所期望的(不算漂亮,但用 tab 定界,以便于導入電子表格):
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下一頁閱讀全文

標簽:昌都 海口 臨滄 泰安 西寧 營口 宿遷 南京

巨人網絡通訊聲明:本文標題《awk基礎知識小結第1/2頁》,本文關鍵詞  awk,基礎知識,小結,第,2頁,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《awk基礎知識小結第1/2頁》相關的同類信息!
  • 本頁收集關于awk基礎知識小結第1/2頁的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久综合色综合88| 久久99精品国产91久久来源 | 亚洲女与黑人做爰| 亚洲日本va午夜在线电影| 久久久精品免费网站| 国产人成一区二区三区影院| 日韩你懂的在线播放| 欧美刺激脚交jootjob| 国产欧美一区二区精品性| 国产精品嫩草影院com| 亚洲欧美电影院| 日本不卡不码高清免费观看 | 亚洲欧洲精品一区二区三区不卡| 欧美极品xxx| 日本一区中文字幕| 成人av资源下载| 欧美私模裸体表演在线观看| 69久久99精品久久久久婷婷| 久久精品这里都是精品| 午夜久久电影网| 国产激情视频一区二区三区欧美| 在线视频国产一区| 国产三级三级三级精品8ⅰ区| 亚洲精品视频在线| 成人一级片在线观看| 91精品午夜视频| 亚洲综合视频网| 色综合久久综合网| 综合久久综合久久| av午夜一区麻豆| 国产精品久久久久久久久搜平片 | 欧美精品v国产精品v日韩精品| 国产亚洲欧美色| 国产精品1区2区3区在线观看| 欧美一卡在线观看| 日本成人超碰在线观看| 欧美午夜片在线观看| 一区二区三区丝袜| 色综合中文字幕国产 | 亚洲精品在线观| 国产在线不卡一区| 国产精品久久久久久亚洲毛片| 国产裸体歌舞团一区二区| 国产免费成人在线视频| 91蜜桃在线观看| 日韩精品乱码免费| 精品sm捆绑视频| 91麻豆高清视频| 日韩成人一区二区| 国产精品国产馆在线真实露脸 | 国产91在线看| 性做久久久久久久免费看| 精品捆绑美女sm三区| 高清在线观看日韩| 亚洲网友自拍偷拍| 国产欧美一区二区精品久导航| 国产在线精品一区二区夜色 | 三级久久三级久久| 久久久久久久一区| 欧美情侣在线播放| 97久久精品人人澡人人爽| 日韩国产欧美在线视频| 亚洲欧美另类在线| 中文字幕一区在线| 国产精品高潮久久久久无| 精品国产一区二区三区不卡| 欧美日韩情趣电影| 91麻豆免费观看| 91麻豆国产在线观看| 国产福利电影一区二区三区| 国产一区二区在线看| 奇米影视7777精品一区二区| 亚洲主播在线观看| 亚洲大型综合色站| 日韩精品三区四区| 毛片av一区二区| 国产aⅴ综合色| 白白色 亚洲乱淫| 色8久久精品久久久久久蜜| 北岛玲一区二区三区四区| 99久久国产综合精品麻豆| 色婷婷激情一区二区三区| 欧美三级日韩三级国产三级| 欧美精品久久99| 欧美精品一区二区三区一线天视频 | 欧美国产一区视频在线观看| 精品久久久久av影院| 欧美激情艳妇裸体舞| 国产精品久久久一本精品 | 中文字幕佐山爱一区二区免费| 国产精品动漫网站| 一区二区在线观看免费视频播放| 亚洲一区中文日韩| 国产裸体歌舞团一区二区| 色噜噜狠狠成人中文综合| 欧美成人福利视频| 亚洲一级二级在线| 99久久精品国产精品久久| 日韩视频免费观看高清在线视频| 久久久另类综合| 五月开心婷婷久久| 欧美综合欧美视频| 亚洲欧美自拍偷拍色图| 国产麻豆午夜三级精品| 717成人午夜免费福利电影| 亚洲免费观看高清在线观看| 国产一级精品在线| 91精品国产综合久久精品 | 欧美一区二区三区在线电影| 精品日产卡一卡二卡麻豆| 亚洲色图.com| 风间由美中文字幕在线看视频国产欧美| 午夜久久久久久久久久一区二区| 91片在线免费观看| 国产免费成人在线视频| 蜜桃视频在线一区| 亚洲精品一区二区三区蜜桃下载 | 91亚洲男人天堂| 国产女人水真多18毛片18精品视频| 七七婷婷婷婷精品国产| 91久久国产综合久久| 日本中文字幕一区二区有限公司| 91麻豆产精品久久久久久| 亚洲欧美日韩人成在线播放| 成人av在线资源| 99re热视频这里只精品| 亚洲一区在线视频| 色伊人久久综合中文字幕| 一区二区三区在线视频观看| 色婷婷久久久综合中文字幕 | 国产精品丝袜在线| av亚洲精华国产精华精| 亚洲一区二区成人在线观看| 色88888久久久久久影院野外| 亚洲欧美日韩综合aⅴ视频| 国产精一品亚洲二区在线视频| 国产亚洲欧洲997久久综合| 91丨九色丨黑人外教| 亚洲国产综合人成综合网站| 欧美日韩视频专区在线播放| 久久精品72免费观看| 国产精品视频看| 日韩一区二区高清| av在线不卡电影| 捆绑调教一区二区三区| 国产女人18毛片水真多成人如厕| 成a人片亚洲日本久久| 三级一区在线视频先锋| 亚洲日穴在线视频| 国产午夜精品一区二区三区嫩草 | 一区二区三区在线视频观看| 欧美精品一区二区三区在线| 91精品国产乱码久久蜜臀| 欧美制服丝袜第一页| 91蜜桃传媒精品久久久一区二区 | 欧美日韩国产经典色站一区二区三区| 国产精品一区二区无线| 日韩**一区毛片| 亚洲国产精品99久久久久久久久| 欧美日韩一二三| 日韩欧美国产一区二区在线播放| 久99久精品视频免费观看| 婷婷国产v国产偷v亚洲高清| 亚洲精品老司机| 亚洲电影一区二区三区| 国产精品乱人伦中文| 国产精品欧美经典| 一级女性全黄久久生活片免费| 亚洲一区二区三区四区五区中文 | 亚洲欧美另类在线| 亚洲一区日韩精品中文字幕| 国产精品第一页第二页第三页| 亚洲欧美偷拍卡通变态| 亚洲韩国一区二区三区| 日本一不卡视频| 成人av电影在线| 91精品国产一区二区三区蜜臀| 久久久久9999亚洲精品| 欧美一级精品在线| 亚洲男帅同性gay1069| 久久av老司机精品网站导航| 国产高清一区日本| 日韩一级大片在线| 亚洲三级免费电影| 国产成人在线色| 欧美性大战久久| 26uuu国产在线精品一区二区| 国产日韩欧美精品综合| 美女网站色91| 欧美视频一区在线观看| 日本一区二区动态图| 亚洲成人免费av| 91丨porny丨户外露出| 欧美岛国在线观看| 午夜精品在线视频一区| 日韩精品一区二区三区蜜臀| 亚洲国产日产av| 91精品婷婷国产综合久久| 日本欧美韩国一区三区| 欧美一级黄色大片|