精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何用 Python 快速揭示數據之間的各種關系

開發 后端
如果你具備 Matplotlib 和 Pandas 的基本知識,并且想探索一下 Seaborn,那么這篇文章正是不錯的起點。

探索性數據分析(EDA)涉及兩個基本步驟:

  • 數據分析(數據預處理、清洗以及處理)。
  • 數據可視化(使用不同類型的圖來展示數據中的關系)。

[[349740]]

Pandas 是 Python 中最常用的數據分析庫。Python 提供了大量用于數據可視化的庫,Matplotlib 是最常用的,它提供了對繪圖的完全控制,并使得繪圖自定義變得容易。

但是,Matplotlib 缺少了對 Pandas 的支持。而 Seaborn 彌補了這一缺陷,它是建立在 Matplotlib 之上并與 Pandas 緊密集成的數據可視化庫。

然而,Seaborn 雖然活干得漂亮,但是函數眾多,讓人不知道到底該怎么使用它們?不要慫,本文就是為了理清這點,讓你快速掌握這款利器。

這篇文章主要涵蓋如下內容,

  • Seaborn 中提供的不同的繪圖類型。
  • Pandas 與 Seaborn 的集成如何實現以最少的代碼繪制復雜的多維圖?
  • 如何在 Matplotlib 的輔助下自定義 Seaborn 繪圖設置?

誰適合閱讀這篇文章?

如果你具備 Matplotlib 和 Pandas 的基本知識,并且想探索一下 Seaborn,那么這篇文章正是不錯的起點。

如果目前只掌握 Python,建議翻閱文末相關文章,特別是在掌握 Pandas 的基本使用之后再回到這里來或許會更好一些。

一、Matplotlib

盡管僅使用最簡單的功能就可以完成許多任務,但是了解 Matplotlib 的基礎非常重要,其原因有兩個,

  • Seaborn 在底層使用 Matplotlib 繪圖。
  • 一些自定義項需要直接使用 Matplotlib。

這里對 Matplotlib 的基礎作個簡單概述。下圖顯示了 Matplotlib 窗口的各個要素。

需要了解的三個主要的類是圖形(Figure),圖軸(Axes)以及坐標軸(Axis)。

  • 圖形(Figure):它指的就是你看到的整個圖形窗口。同一圖形中可能有多個子圖(圖軸)。在上面的示例中,在一個圖形中有四個子圖(圖軸)。
  • 圖軸(Axes):圖軸就是指圖形中實際繪制的圖。一個圖形可以有多個圖軸,但是給定的圖軸只是整個圖形的一部分。在上面的示例中,我們在一個圖形中有四個圖軸。
  • 坐標軸(Axis):坐標軸是指特定圖軸中的實際的 x-軸和 y-軸。

本帖子中的每個示例均假設已經加載所需的模塊以及數據集,如下所示,

  1. import pandas as pd 
  2. import numpy as np 
  3. from matplotlib import pyplot as plt 
  4. import seaborn as sns 
  5.  
  6. tips = sns.load_dataset('tips') 
  7. iris = sns.load_dataset('iris') 
  1. import matplotlib 
  2. matplotlib.style.use('ggplot') 
  1. tips.head() 

  1. iris.head() 

讓我們通過一個例子來理解一下 Figure 和 Axes 這兩個類。

  1. dates = ['1981-01-01', '1981-01-02', '1981-01-03', '1981-01-04', '1981-01-05', 
  2.          '1981-01-06', '1981-01-07', '1981-01-08', '1981-01-09', '1981-01-10'] 
  3.  
  4. min_temperature = [20.7, 17.9, 18.8, 14.6, 15.8, 15.8, 15.8, 17.4, 21.8, 20.0] 
  5. max_temperature = [34.7, 28.9, 31.8, 25.6, 28.8, 21.8, 22.8, 28.4, 30.8, 32.0] 
  6.  
  7. fig, axes = plt.subplots(nrows=1ncols=1figsize=(10,5)); 
  8. axes.plot(dates, min_temperature, label='Min Temperature'); 
  9. axes.plot(dates, max_temperature, label = 'Max Temperature'); 
  10. axes.legend(); 

plt.subplots() 創建一個 Figure 對象實例,以及 nrows x ncols 個 Axes 實例,并返回創建的 Figure 對象和 Axes 實例。在上面的示例中,由于我們傳遞了 nrows = 1 和 ncols = 1,因此它僅創建一個 Axes 實例。如果 nrows > 1 或 ncols > 1,則將創建一個 Axes 網格并將其返回為 nrows 行 ncols 列的 numpy 數組。

Axes 類最常用的自定義方法有,

  1. Axes.set_xlabel()         Axes.set_ylabel() 
  2. Axes.set_xlim()           Axes.set_ylim() 
  3. Axes.set_xticks()         Axes.set_yticks() 
  4. Axes.set_xticklabels()    Axes.set_yticklabels() 
  5. Axes.set_title() 
  6. Axes.tick_params() 

下面是一個使用上述某些方法進行自定義的例子,

  1. fontsize =20 
  2. fig, axes = plt.subplots(nrows=1ncols=1figsize=(15,7)) 
  3. axes.plot(dates, min_temperature, label='Min Temperature'
  4. axes.plot(dates, max_temperature, label='Max Temperature'
  5.  
  6. axes.set_xlabel('Date', fontsizefontsize=fontsize) 
  7. axes.set_ylabel('Temperature', fontsizefontsize=fontsize) 
  8.  
  9. axes.set_title('Daily Min and Max Temperature', fontsizefontsize=fontsize) 
  10.  
  11. axes.set_xticks(dates) 
  12. axes.set_xticklabels(dates) 
  13. axes.tick_params('x', labelsize=fontsizelabelrotation=30size=15
  14.  
  15.  
  16. axes.set_ylim(10,40) 
  17. axes.set_yticks(np.arange(10,41,2)) 
  18. axes.tick_params('y',labelsize=fontsize
  19.  
  20. axes.legend(fontsizefontsize=fontsize,loc='upper left'bbox_to_anchor=(1,1)); 

上面我們快速了解了下 Matplotlib 的基礎知識,現在讓我們進入 Seaborn。

二、Seaborn

Seaborn 中的每個繪圖函數既是圖形級函數又是圖軸級函數,因此有必要了解這兩者之間的區別。

  • 如前所述,圖形指的是你看到的整個繪圖窗口上的圖,而圖軸指的是圖形中的一個特定子圖。
  • 圖軸級函數只繪制到單個 Matplotlib 圖軸上,并不影響圖形的其余部分。
  • 而圖形級函數則可以控制整個圖形。

我們可以這么來理解這一點,圖形級函數可以調用不同的圖軸級函數在不同的圖軸上繪制不同類型的子圖。

  1. sns.set_style('darkgrid') 

1. 圖軸級函數

下面羅列的是 Seaborn 中所有圖軸級函數的詳細列表。

關系圖 Relational Plots:

  • scatterplot( )
  • lineplot( )

類別圖 Categorical Plots:

  • striplot( )、swarmplot( )
  • boxplot( )、boxenplot( )
  • violinplot( )、countplot( )
  • pointplot( )、barplot( )

分布圖 Distribution Plots:

  • distplot( )
  • kdeplot( )
  • rugplot( )

回歸圖 Regression Plots:

  • regplot( )
  • residplot( )

矩陣圖 MatrixPlots( ):

  • heatmap( )

使用任何圖軸級函數需要了解的兩點,

  • 將輸入數據提供給圖軸級函數的不同方法。
  • 指定用于繪圖的圖軸。

(1) 將輸入數據提供給圖軸級函數的不同方法

a. 列表、數組或系列

將數據傳遞到圖軸級函數的最常用方法是使用迭代器,例如列表 list,數組 array 或序列 series

  1. total_bill = tips['total_bill'].values 
  2. tip = tips['tip'].values 
  3.  
  4. fig = plt.figure(figsize=(10, 5)) 
  5. sns.scatterplot(total_bill, tip, s=15); 

  1. tip = tips['tip'].values 
  2. day = tips['day'].values 
  3.  
  4. fig = plt.figure(figsize=(10, 5)) 
  5. sns.boxplot(day, tip, palette="Set2"); 

b. 使用 Pandas 的 Dataframe 類型以及列名。

Seaborn 受歡迎的主要原因之一是它可以直接可以與 Pandas 的 Dataframes 配合使用。在這種數據傳遞方法中,列名應傳遞給 x 和 y 參數,而 Dataframe 應傳遞給 data 參數。

  1. fig = plt.figure(figsize=(10, 5)) 
  2. sns.scatterplot(x='total_bill'y='tip'data=tipss=50); 

  1. fig = plt.figure(figsize=(10, 5)) 
  2. sns.boxplot(x='day'y='tip'data=tips); 

c. 僅傳遞 Dataframe

在這種數據傳遞方式中,僅將 Dataframe 傳遞給 data 參數。數據集中的每個數字列都將使用此方法繪制。此方法只能與以下軸級函數一起使用,

  • stripplot( )、swarmplot( )
  • boxplot( )、boxenplot( )、violinplot( )、pointplot( )
  • barplot( )、countplot( )

使用上述圖軸級函數來展示某個數據集中的多個數值型變量的分布,是這種數據傳遞方式的常見用例。

  1. fig = plt.figure(figsize=(10, 5)) 
  2. sns.boxplot(data=iris); 

(2) 指定用于繪圖的圖軸

Seaborn 中的每個圖軸級函數都帶有一個 ax 參數。傳遞給 ax 參數的 Axes 將負責具體繪圖。這為控制使用具體圖軸進行繪圖提供了極大的靈活性。例如,假設要查看總賬單 bill 和小費 tip 之間的關系(使用散點圖)以及它們的分布(使用箱形圖),我們希望在同一個圖形但在不同圖軸上展示它們。

  1. fig, axes = plt.subplots(1, 2, figsize=(10, 7)) 
  2. sns.scatterplot(x='total_bill'y='tip'data=tipsax=axes[1]); 
  3. sns.boxplot(data = tips[['total_bill','tip']], ax=axes[0]); 

每個圖軸級函數還會返回實際在其上進行繪圖的圖軸。如果將圖軸傳遞給了 ax 參數,則將返回該圖軸對象。然后可以使用不同的方法(如Axes.set_xlabel( ),Axes.set_ylabel( ) 等)對返回的圖軸對象進行進一步自定義設置。

如果沒有圖軸傳遞給 ax 參數,則 Seaborn 將使用當前(活動)圖軸來進行繪制。

  1. fig, curr_axes = plt.subplots() 
  2. scatter_plot_axes = sns.scatterplot(x='total_bill'y='tip'data=tips
  3. id(curr_axes) == id(scatter_plot_axes) 

True

在上面的示例中,即使我們沒有將 curr_axes(當前活動圖軸)顯式傳遞給 ax 參數,但 Seaborn 仍然使用它進行了繪制,因為它是當前的活動圖軸。id(curr_axes) == id(scatter_plot_axes) 返回 True,表示它們是相同的軸。

如果沒有將圖軸傳遞給 ax 參數并且沒有當前活動圖軸對象,那么 Seaborn 將創建一個新的圖軸對象以進行繪制,然后返回該圖軸對象。

Seaborn 中的圖軸級函數并沒有參數用來控制圖形的尺寸。但是,由于我們可以指定要使用哪個圖軸進行繪圖,因此可以通過為 ax 參數傳遞圖軸來控制圖形尺寸,如下所示。

  1. fig, axes = plt.subplots(1, 1, figsize=(10, 5)) 
  2. sns.scatterplot(x='total_bill'y='tip'data=tipsax=axes); 

2. 圖形級函數

在瀏覽多維數據集時,數據可視化的最常見用例之一就是針對各個數據子集繪制同一類圖的多個實例。

Seaborn 中的圖形級函數就是為這種情形量身定制的。

  • 圖形級函數可以完全控制整個圖形,并且每次調用圖形級函數時,它都會創建一個包含多個圖軸的新圖形。
  • Seaborn 中三個最通用的圖形級函數是 FacetGrid、PairGrid 以及 JointGrid。

(1) FacetGrid

考慮下面的用例,我們想可視化不同數據子集上的總賬單和小費之間的關系(通過散點圖)。數據的每個子集均按以下變量的值的唯一組合進行分類,

  • 星期幾(星期四、五、六、日)
  • 是否吸煙(是或否)
  • 性別(男性或女性)

如下所示,我們可以用 Matplotlib 和 Seaborn 輕松完成這個操作,

  1. row_variable = 'day' 
  2. col_variable = 'smoker' 
  3. hue_variable = 'sex' 
  4. row_variables = tips[row_variable].unique() 
  5. col_variables = tips[col_variable].unique() 
  6. num_rows = row_variables.shape[0] 
  7. num_cols = col_variables.shape[0] 
  8.  
  9. fig,axes = plt.subplots(num_rows, num_cols, sharex=Truesharey=Truefigsize=(15,10)) 
  10. subset = tips.groupby([row_variable,col_variable]) 
  11. for row in range(num_rows): 
  12.     for col in range(num_cols): 
  13.         ax = axes[row][col] 
  14.         row_id = row_variables[row] 
  15.         col_id = col_variables[col] 
  16.         ax_data = subset.get_group((row_id, col_id)) 
  17.         sns.scatterplot(x='total_bill'y='tip'data=ax_datahue=hue_variable,axax=ax); 
  18.         title = row_variable + ' : '  + row_id + ' | ' + col_variable + ' : ' + col_id 
  19.         ax.set_title(title); 

分析一下,上面的代碼可以分為三個步驟,

  • 為每個數據子集創建一個圖軸(子圖)
  • 將數據集劃分為子集
  • 在每個圖軸上,使用對應于該圖軸的數據子集來繪制散點圖

在 Seaborn 中,可以將上面三部曲進一步簡化為兩部曲。

  • 步驟 1 可以在 Seaborn 中可以使用 FacetGrid( ) 完成
  • 步驟 2 和步驟 3 可以使用 FacetGrid.map( ) 完成

使用 FacetGrid,我們可以創建圖軸并結合 row,col 和 hue 參數將數據集劃分為三個維度。一旦創建好 FacetGrid 后,可以將具體的繪圖函數作為參數傳遞給 FacetGrid.map( ) 以在所有圖軸上繪制相同類型的圖。在繪圖時,我們還需要傳遞用于繪圖的 Dataframe 中的具體列名。

  1. facet_grid = sns.FacetGrid(row='day'col='smoker'hue='sex'data=tipsheight=2aspect=2.5) 
  2. facet_grid.map(sns.scatterplot, 'total_bill', 'tip') 
  3. facet_grid.add_legend(); 

Matplotlib 為使用多個圖軸繪圖提供了良好的支持,而 Seaborn 在它基礎上將圖的結構與數據集的結構直接連接起來了。

使用 FacetGrid,我們既不必為每個數據子集顯式地創建圖軸,也不必顯式地將數據劃分為子集。這些任務由 FacetGrid( ) 和 FacetGrid.map( ) 分別在內部完成了。

我們可以將不同的圖軸級函數傳遞給 FacetGrid.map( )。

另外,Seaborn 提供了三個圖形級函數(高級接口),這些函數在底層使用 FacetGrid( ) 和 FacetGrid.map( )。

  • relplot( )
  • catplot( )
  • lmplot( )

上面的圖形級函數都使用 FacetGrid( ) 創建多個圖軸 Axes,并用參數 kind 記錄一個圖軸級函數,然后在內部將該參數傳遞給 FacetGrid.map( )。上述三個函數分別使用不同的圖軸級函數來實現不同的繪制。

  1. relplot() - FacetGrid() + lineplot()   / scatterplot()  
  2. catplot() - FacetGrid() + stripplot()  / swarmplot()   / boxplot()  
  3.                           boxenplot()  / violinplot()  / pointplot()  
  4.                           barplot()    / countplot()  
  5. lmplot()  - FacetGrid() + regplot() 

與直接使用諸如 relplot( )、catplot( ) 或 lmplot( ) 之類的高級接口相比,顯式地使用 FacetGrid 提供了更大的靈活性。例如,使用 FacetGrid( ),我們還可以將自定義函數傳遞給 FacetGrid.map( ),但是對于高級接口,我們只能使用內置的圖軸級函數指定給參數 kind。如果你不需要這種靈活性,則可以直接使用這些高級接口函數。

  1. grid = sns.relplot(x='total_bill'y='tip'row='day'col='smoker'hue='sex'data=tipskind='scatter'height=3aspect=2.0) 

  1. sns.catplot(col='day'kind='box'data=tipsx='sex'y='total_bill'hue='smoker'height=6aspect=0.5) 

  1. sns.lmplot(col='day'data=tipsx='total_bill'y='tip'hue='sex'height=6aspect=0.5) 

(2) PairGrid

PairGrid 用于繪制數據集中變量之間的成對關系。每個子圖顯示一對變量之間的關系。考慮以下用例,我們希望可視化每對變量之間的關系(通過散點圖)。雖然可以在 Matplotlib 中也能完成此操作,但如果用 Seaborn 就會變得更加便捷。

  1. iris = sns.load_dataset('iris') 
  2. g = sns.PairGrid(iris) 

此處的實現主要分為兩步,

  • 為每對變量創建一個圖軸
  • 在每個圖軸上,使用與該對變量對應的數據繪制散點圖

第 1 步可以使用 PairGrid( ) 來完成。第 2 步可以使用 PairGrid.map( )來完成。

因此,PairGrid( ) 為每對變量創建圖軸,而 PairGrid.map( ) 使用與該對變量相對應的數據在每個圖軸上繪制曲線。我們可以將不同的圖軸級函數傳遞給 PairGrid.map( )。

  1. grid = sns.PairGrid(iris) 
  2. grid.map(sns.scatterplot) 

  1. grid = sns.PairGrid(iris, diag_sharey=Truedespine=False
  2. grid.map_lower(sns.scatterplot) 
  3. grid.map_diag(sns.kdeplot) 

  1. grid = sns.PairGrid(iris, hue='species'
  2. grid.map_diag(sns.distplot) 
  3. grid.map_offdiag(sns.scatterplot) 

該圖不必是正方形的:可以使用單獨的變量來定義行和列,

  1. x_vars = ['sepal_length', 'sepal_width', 'petal_length', 'petal_width'] 
  2. y_vars = ['sepal_length'] 
  3. grid = sns.PairGrid(iris, hue='species'x_varsx_vars=x_vars, y_varsy_vars=y_vars, height=3
  4. grid.map_offdiag(sns.scatterplot, s=150
  5. # grid.map_diag(sns.kdeplot) 
  6. grid.add_legend() 

(3) JointGrid

當我們要在同一圖中繪制雙變量聯合分布和邊際分布時,使用 JointGrid。可以使用 scatter plot、regplot 或 kdeplot 可視化兩個變量的聯合分布。變量的邊際分布可以通過直方圖和/或 kde 圖可視化。

  • 用于聯合分布的圖軸級函數必須傳遞給 JointGrid.plot_joint( )。
  • 用于邊際分布的軸級函數必須傳遞給 JointGrid.plot_marginals( )。
  1. grid = sns.JointGrid(x="total_bill"y="tip"data=tipsheight=8
  2. grid.plot(sns.regplot, sns.distplot); 

  1. grid = sns.JointGrid(x="total_bill"y="tip"data=tipsheight=8
  2. gridgrid = grid.plot_joint(plt.scatter, color=".5"edgecolor="white"
  3. gridgrid = grid.plot_marginals(sns.distplot, kde=Truecolor=".5"

  1. g = sns.JointGrid(x="total_bill"y="tip"data=tipsheight=8
  2. gg = g.plot_joint(plt.scatter, color="g"marker='$\clubsuit$'edgecolor="white"alpha=.6) 
  3. _ = g.ax_marg_x.hist(tips["total_bill"], color="b"alpha=.36, 
  4.                       bins=np.arange(0, 60, 5)) 
  5. _ = g.ax_marg_y.hist(tips["tip"], color="r"alpha=.36, 
  6.                      orientation="horizontal"
  7.                      bins=np.arange(0, 12, 1)) 

添加帶有統計信息的注釋(Annotation),該注釋匯總了雙變量關系,

  1. from scipy import stats 
  2. g = sns.JointGrid(x="total_bill"y="tip"data=tipsheight=8
  3. gg = g.plot_joint(plt.scatter, color="b"alpha=0.36, s=40edgecolor="white"
  4. gg = g.plot_marginals(sns.distplot, kde=Falsecolor="g"
  5.  
  6. rsquare = lambda a, b: stats.pearsonr(a, b)[0] ** 2 
  7. gg = g.annotate(rsquare, template="{stat}: {val:.2f}"stat="$R^2$"loc="upper left"fontsize=12

3. 小結

探索性數據分析(EDA)涉及兩個基本步驟,

  • 數據分析(數據預處理、清洗以及處理)。
  • 數據可視化(使用不同類型的圖來展示數據中的關系)。

Seaborn 與 Pandas 的集成有助于以最少的代碼制作復雜的多維圖,

  • Seaborn 中的每個繪圖函數都是圖軸級函數或圖形級函數。
  • 圖軸級函數繪制到單個 Matplotlib 圖軸上,并且不影響圖形的其余部分。
  • 圖形級函數控制整個圖形。

 

責任編輯:趙寧寧 來源: 機器學習與數學
相關推薦

2022-04-12 11:22:13

物聯網云計算

2017-04-17 08:35:12

Python數學算法

2017-05-02 13:38:51

CSS繪制形狀

2020-07-10 09:49:53

數據清理數據分析查找異常

2021-01-14 12:17:52

大數據數據分析技術

2012-05-31 14:54:59

Hadoop大數據

2018-10-10 09:00:00

前端框架Angular

2021-07-13 19:33:41

大數據云計算

2021-06-24 08:00:00

開發Hugo工具

2025-01-02 12:59:55

Python面向對象編程type

2018-08-21 07:50:06

Python 大數據編程語言

2020-11-06 17:42:02

Python開發工具

2020-04-03 15:22:49

Hadoop數據倉庫數據庫

2018-08-14 05:05:25

2015-07-06 13:36:14

Redis微博關注關系

2012-10-31 09:20:45

數據中心制冷PUE

2025-01-21 11:52:12

AnsiblePython自動化運維

2010-03-26 15:55:47

Python腳本

2024-03-04 11:12:20

大數據物聯網

2019-01-15 14:21:13

Python數據分析數據
點贊
收藏

51CTO技術棧公眾號

99精品久久久| 亚洲涩涩在线| 国产一区日韩二区欧美三区| 萌白酱国产一区二区| 天堂av8在线| 国产福利在线免费观看| 99久久精品99国产精品| 国产精品网红直播| 国产无套内射又大又猛又粗又爽| 秋霞影院一区二区三区| 欧美三区免费完整视频在线观看| 国产女主播av| 国产在线黄色| 国模无码大尺度一区二区三区| 91精品国产91久久| 熟女少妇a性色生活片毛片| 国产三级精品三级在线观看国产| 欧美日韩免费在线观看| 国产成人三级视频| 国产小视频在线| 国产成a人亚洲精| 国产精品美女久久久久久免费 | 国产亚洲一区| 亚洲а∨天堂久久精品9966| 国产原创精品在线| 在线天堂中文资源最新版| 亚洲精品中文字幕在线观看| 欧美精品七区| 色婷婷视频在线| 国产精品99久久久久久似苏梦涵| 国产精品免费在线免费| 久久久久久91亚洲精品中文字幕| 综合久久婷婷| 丝袜一区二区三区| 高潮毛片无遮挡| 欧美黑白配在线| 亚洲国产成人在线视频| 色欲欲www成人网站| 电影一区中文字幕| 欧美人与z0zoxxxx视频| 日本999视频| 香蕉视频亚洲一级| 欧美性xxxx在线播放| 日本丰满少妇xxxx| 女子免费在线观看视频www| 国产精品的网站| 亚洲精品高清国产一线久久| 精品美女视频在线观看免费软件 | 国产伦理一区二区三区| 国产三级按摩推拿按摩| 精品一区二区三区久久| 国产精品一久久香蕉国产线看观看| 中文在线第一页| 老司机免费视频久久| 26uuu久久噜噜噜噜| 日韩精品乱码久久久久久| 欧美天天视频| 国自产精品手机在线观看视频| 成人免费看片98| 在线国产欧美| 欧美有码在线观看| 69亚洲精品久久久蜜桃小说| 久久久999| 国产精品久久久久久久久久久不卡| 中文av免费观看| 精品亚洲国内自在自线福利| 亚洲精品欧美日韩专区| 亚洲xxx在线| av色综合久久天堂av综合| 精品国产乱码久久久久久久软件 | 久久精品国产久精国产一老狼| 特黄一区二区三区| 亚洲综合中文| 久久久人成影片一区二区三区观看| 亚洲国产精一区二区三区性色| 国产欧美一区二区色老头| 国产va免费精品高清在线观看 | 麻豆国产精品777777在线| 国产一区二区在线播放| wwwav在线播放| 97久久人人超碰| 亚洲 国产 日韩 综合一区| 麻豆传媒在线免费看| 亚洲尤物视频在线| 国产成人无码av在线播放dvd| 亚洲精品一区三区三区在线观看| 正在播放亚洲一区| 一级特黄a大片免费| 国产伦精品一区二区三区千人斩| 日韩在线不卡视频| 亚洲成人生活片| 国产日韩专区| 成人有码视频在线播放| 日韩在线视频免费| 国产精品网站在线| 青青青在线视频播放| 欧美黑人疯狂性受xxxxx野外| 欧美久久久久久蜜桃| 亚洲男女在线观看| 99视频精品全国免费| 国产www在线| 亚洲国产精品yw在线观看| 成人在线免费观看网址| 青草影视电视剧免费播放在线观看| 午夜精品在线视频一区| 欧美自拍小视频| 成人香蕉社区| 日韩在线视频免费观看| 中文字幕一区二区三区精品| 久久成人av少妇免费| 精品无人区一区二区三区| 在线a人片免费观看视频| 亚洲成a人v欧美综合天堂下载| 香蕉视频禁止18| 欧美人体视频| 欧美日韩福利视频| 亚洲一区二区激情| 久久人人爽人人爽| 成人免费毛片在线观看| 精品视频一二| 最新中文字幕亚洲| 91精品国产乱码在线观看| 免费成人在线观看| 欧洲精品亚洲精品| 神马久久午夜| 亚洲精品一区二区三区香蕉| 香蕉成人在线视频| 日本亚洲天堂网| 欧美大香线蕉线伊人久久| 黄色一级片一级片| 国产综合在线播放| 国产精品国产成人国产三级| 国产99久久九九精品无码| 日韩最新av| 欧美成人在线影院| 国产精品乱码久久久| 中文字幕免费在线观看视频一区| 久久久久久久午夜| 久久悠悠精品综合网| 欧美激情欧美激情| 亚洲黄色在线观看视频| 一区二区在线看| 在线视频日韩欧美| 综合激情视频| 97在线中文字幕| 亚洲男同gay网站| 日韩欧美自拍偷拍| 国内偷拍精品视频| 国产a久久麻豆| 美女黄色免费看| aaa国产精品| 高清欧美性猛交xxxx黑人猛交| 精品国产亚洲av麻豆| 亚洲狼人国产精品| 在线观看你懂的视频| 欧美成人一区二免费视频软件| 亚洲xxxx3d| 精精国产xxxx视频在线中文版| 日韩欧美色综合网站| 久久久久成人精品无码| 成人激情视频网站| 欧美三级一级片| 欧美女优在线视频| 国产欧亚日韩视频| 菠萝蜜视频国产在线播放| 欧美一区二区三区日韩视频| 欧美精品videos极品| 成人午夜精品一区二区三区| 久久久久久久久久网| 亚洲成aⅴ人片久久青草影院| 日本国产欧美一区二区三区| 国产精品麻豆一区二区三区| 欧美色倩网站大全免费| www色aa色aawww| 午夜影院在线视频| 亚洲性色视频| 国产视频不卡| 性欧美videohd高精| 亚洲欧美激情诱惑| 久久久com| 日本一区二区三区视频在线| xvideos亚洲人网站| 亚洲av综合色区无码一区爱av| 午夜精品久久久| 中文字幕第20页| 韩国欧美国产1区| 九九爱精品视频| 日本久久精品| 国产精品12| 亚洲精品在线影院| 欧美黑人xxx| 国产精品影院在线| 日韩欧美一级二级三级| 国产一区二区视频网站| 最新国产の精品合集bt伙计| 免费日本黄色网址| 免费观看30秒视频久久| 婷婷无套内射影院| 久久在线视频免费观看| 国产一区再线| 日韩三级成人| 国产91在线播放九色快色| 国内外激情在线| 亚洲欧美资源在线| 亚洲AV无码成人片在线观看 | 国产综合色激情| 韩国国内大量揄拍精品视频| 在线中文资源天堂| 亚洲精品国产成人| 国产理论片在线观看| 色视频一区二区| 日本少妇裸体做爰| 亚洲精品国久久99热| 人妻视频一区二区| 99久久99久久精品免费观看| 欧美日韩理论片| 免费高清在线一区| 欧美激情精品久久久久久小说| 激情五月***国产精品| 中文字幕色一区二区| 一本久久青青| 国产在线一区二区三区播放| 警花av一区二区三区| 国产精品久久久久久久久久免费 | 狠狠躁夜夜躁人人躁婷婷91| 成人免费视频网站入口::| 欧美激情一区不卡| 中文字幕一区二区三区人妻电影| 北岛玲一区二区三区四区| 国产一级二级av| 国产高清在线精品| 国产精品igao网网址不卡| 蜜桃在线一区二区三区| www.日日操| 日韩精品91亚洲二区在线观看 | 性欧美精品一区二区三区在线播放| 亚州综合一区| 久久精品国产一区二区三区不卡| 第四色中文综合网| 国产成人亚洲欧美| 99国产精品久久一区二区三区| 91香蕉电影院| 免费精品一区| 春色成人在线视频| 波多野结衣一区二区三区免费视频| http;//www.99re视频| 亚洲国产高清在线观看| 91久久精品一区二区别| 日本免费精品| 国产成人精品福利一区二区三区| 中文字幕亚洲在线观看| 国产精品v欧美精品∨日韩| 亚洲一区二区三区四区电影 | 亚洲成a人v欧美综合天堂下载| 国产精品不卡av| 精品国产精品三级精品av网址| 日韩欧美亚洲视频| 一本高清dvd不卡在线观看| 亚洲综合图片网| 欧美天堂一区二区三区| 97人妻精品一区二区三区软件| 欧美精品丝袜久久久中文字幕| 91成品人影院| 精品久久人人做人人爰| 天天干在线观看| 亚洲欧洲视频在线| 欧美成人精品一区二区男人看| 日韩中文字幕精品视频| av电影免费在线观看| 久久久久亚洲精品| 伊人久久视频| 国产在线观看精品| 这里视频有精品| 免费看成人午夜电影| 成人在线丰满少妇av| 青青视频免费在线观看| 国产女优一区| 999在线观看| 成人精品视频.| 女女互磨互喷水高潮les呻吟| 136国产福利精品导航| 久草资源在线视频| 色婷婷综合视频在线观看| 91亚洲国产成人精品一区| 精品黑人一区二区三区久久| 日韩三级电影网| 久久久999成人| 成人性生活av| 亚洲综合精品伊人久久| 亚洲瘦老头同性70tv| 色中文字幕在线观看| 在线综合亚洲| 中文字幕剧情在线观看| 99精品视频一区二区三区| 一级免费黄色录像| 黄色一区二区在线| 国产一区二区三区四区视频 | 在线视频自拍| 97av在线视频| 精品一区二区三区免费看| 伊人久久99| 欧美v亚洲v| 日本精品免费观看| 国产精品亚洲一区二区在线观看| 精品国产一区二区三区免费| 日韩欧美中文| 1024av视频| 国产精品一色哟哟哟| 久久亚洲无码视频| 午夜av电影一区| 国产v片在线观看| 国产精品一区在线观看乱码| 日韩大尺度视频| 国产精品网曝门| 国产一级免费视频| 亚洲福利在线视频| 国产在线高清视频| 国产精品欧美日韩久久| 婷婷激情久久| 和岳每晚弄的高潮嗷嗷叫视频| 精品一区二区三区免费观看| 亚洲AV无码国产成人久久| 精品国产乱码久久久久久天美| 国产国语亲子伦亲子| 日韩亚洲欧美中文高清在线| 亚洲电影有码| 欧美高清性xxxxhdvideosex| 亚洲日本国产| 香蕉视频免费网站| 亚洲乱码一区二区三区在线观看| 亚洲图片中文字幕| 宅男66日本亚洲欧美视频| 神马久久资源| 久久资源av| 蘑菇福利视频一区播放| 中文字幕免费高清视频| 亚洲成人在线免费| 亚洲国产精品suv| 欧美激情欧美激情在线五月| 日本精品在线观看| 国产精品va在线观看无码| 国产剧情一区在线| 国产高清在线免费观看| 欧美一级理论性理论a| 国产一二三区在线观看| 成人综合网网址| 亚洲综合中文| 色哟哟无码精品一区二区三区| 亚洲福利一二三区| 四虎在线视频免费观看| 91精品国产高清| 精品一区免费| 欧美婷婷精品激情| 日韩一区在线免费观看| 成 人 免费 黄 色| 久久全球大尺度高清视频| 琪琪久久久久日韩精品| 凹凸国产熟女精品视频| 国产性天天综合网| 在线观看毛片av| 久久天堂电影网| 白嫩白嫩国产精品| 六月激情综合网| 国产精品美女久久福利网站| 国产精品女人久久久| 欧美人与物videos| 丝袜久久网站| 亚洲一级片免费| 亚洲激情图片一区| 五月婷中文字幕| 国产精品视频资源| 午夜欧美视频| 日本japanese极品少妇| 欧美性猛交一区二区三区精品| 国内精品久久久久久野外| 国产精品一区视频网站| 久久五月激情| 日日骚一区二区三区| 精品爽片免费看久久| 国产资源一区| 精品无码国产一区二区三区av| 久久伊人蜜桃av一区二区| 中文在线字幕免费观| 欧美成人午夜影院| 首页亚洲中字| 精品人妻无码中文字幕18禁| 欧美日韩国产一区二区三区| 亚洲图片88| 国产一区二区不卡视频| 久久国产精品第一页| 日韩特黄一级片| 精品国产一区二区三区在线观看| 成人免费直播在线| 99热这里只有精品在线播放| 一区二区三区四区在线播放| 国产中文字幕在线视频| 国产精品视频免费一区| 久久99久久99精品免视看婷婷| 日本中文字幕免费观看| 色偷偷av一区二区三区|