精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

最新欧美人z0oozo0| 国产欧美自拍| 久久这里只有精品6| 国产精品96久久久久久| 精品国产国产综合精品| 激情不卡一区二区三区视频在线| 亚洲在线中文字幕| 免费一区二区三区在在线视频| 亚洲高清视频免费观看| 你懂的视频一区二区| 精品亚洲aⅴ在线观看| 日本黄大片一区二区三区| 丝袜综合欧美| 91丨porny丨户外露出| 国产精品视频色| 毛片a片免费观看| 国产日韩视频在线| 精品国产污污免费网站入口| 激情网站五月天| dy888亚洲精品一区二区三区| 91美女蜜桃在线| 成人性生交大片免费看小说| 亚洲黄色激情视频| 夜间精品视频| 伊人久久精品视频| 欧美xxxxx少妇| **欧美日韩在线| 欧美性猛交xxxx免费看久久久| 日韩一二区视频| av资源网在线观看| 久久日韩粉嫩一区二区三区| 成人欧美一区二区| 国产精品欧美亚洲| 日韩精品电影一区亚洲| 97国产一区二区精品久久呦| 精品一区在线观看视频| 日韩伦理一区| 亚洲日本成人网| www.男人天堂| 亚洲一二av| 5566中文字幕一区二区电影| 黄色一级片播放| 123区在线| 亚洲自拍偷拍图区| 国产精品啪啪啪视频| 天堂中文а√在线| 国产欧美一区二区精品久导航 | 亚洲精品小视频| 中文字幕亚洲日本| 亚洲欧美日产图| 日本人69视频| 精品3atv在线视频| 欧美日韩精品在线| 日韩黄色短视频| 婷婷色在线播放| 亚洲欧美国产高清| 在线观看成人av电影| 日韩在线免费电影| 国产精品毛片高清在线完整版| 日本欧美色综合网站免费| 涩涩视频在线观看免费| 91麻豆国产福利在线观看| 国产日韩精品推荐| 性xxxx视频播放免费| 99国产精品久| 欧美精品成人一区二区在线观看| 亚洲三区在线观看无套内射| av亚洲产国偷v产偷v自拍| 极品尤物一区二区三区| 欧美色图另类| 国产欧美日韩在线看| 亚洲欧美影院| 浪潮av一区| 亚洲一区二区精品久久av| 亚洲人成无码网站久久99热国产| av色在线观看| 色综合久久天天综合网| 日韩手机在线观看视频| 成人亚洲综合| 日韩午夜av电影| 久久久国产精品无码| 久久综合欧美| 久久久国产精品亚洲一区| 欧美高清视频一区二区三区| 亚洲国产激情| 国产精品久久久久久亚洲影视| 亚洲一区在线观| 国产不卡高清在线观看视频| 久久精品日产第一区二区三区乱码| 欧美捆绑视频| 亚洲欧美日韩国产中文在线| 久操网在线观看| 992tv国产精品成人影院| 日韩一区二区三区在线| 国产精品无码网站| 国产精品国产一区| 2025国产精品视频| 一区二区日韩在线观看| 成人av午夜电影| 亚洲人成网站在线观看播放| 欧美videossex| 欧美影视一区在线| 亚洲精品鲁一鲁一区二区三区| 伊人久久大香线蕉无限次| 久久久精品一区| 免费黄色网址在线| 国产精品一区二区黑丝| 日韩精品福利视频| 波多野结衣在线高清| 欧美日韩中文精品| 漂亮人妻被黑人久久精品| 久久一区二区三区电影| 2020国产精品视频| www.97av.com| 国产精品伦一区| 国产男女无遮挡| 欧美经典影片视频网站| 影音先锋日韩有码| 91在线视频在线观看| 国产精品69毛片高清亚洲| 神马影院一区二区三区| 国产va在线视频| 欧美变态凌虐bdsm| 91高清免费看| 美女一区二区三区在线观看| 精品国产综合久久| 久久青青色综合| 9191久久久久久久久久久| 久久久久久久久久久久久久久| 韩国一区二区三区在线观看| 91在线视频一区| av电影在线观看一区二区三区| 婷婷丁香久久五月婷婷| wwwww在线观看| 亚洲美女视频| 国产日韩欧美夫妻视频在线观看| 可以直接在线观看的av| 欧美日韩午夜剧场| 白嫩情侣偷拍呻吟刺激| 国语精品一区| 国产精品一码二码三码在线| 性国产高清在线观看| 欧美一区在线视频| www.毛片com| 精品一区二区三区香蕉蜜桃| 亚洲乱码国产乱码精品天美传媒| 三上悠亚激情av一区二区三区| 日韩av在线免费播放| 日韩女同强女同hd| 99久久久久免费精品国产| 成人一区二区免费视频| 成人台湾亚洲精品一区二区| 久久久久久网址| 亚洲免费一级片| 亚洲国产综合视频在线观看| www.四虎在线| 亚洲看片免费| 精品一区国产| 成人av免费电影网站| 亚洲区中文字幕| 波多野结衣视频观看| 中文字幕乱码日本亚洲一区二区| 成人黄色一区二区| 日韩精品永久网址| 国产在线精品自拍| 99热国产在线| 欧美精品一区二区三区四区| 日韩欧美视频在线免费观看| aa级大片欧美| caoporn超碰97| 婷婷综合激情| 99se婷婷在线视频观看| 国产美女高潮在线| 亚洲人成电影网站色…| 亚洲一区二区三区高清视频| 亚洲精品免费在线| 亚洲男人在线天堂| 久久精品国语| 一道本在线观看视频| 亚洲一二av| 国产精品爱啪在线线免费观看| 成全电影播放在线观看国语| 宅男噜噜噜66一区二区66| 国产一级免费av| 欧美极品美女视频| 丰满人妻一区二区三区53视频| 在线观看日韩av电影| 欧美日韩一区二区视频在线观看| 久久人人视频| 69视频在线播放| 中文字幕在线视频区| 精品日韩在线观看| 久操视频在线免费观看| 九色成人搞黄网站| 亚洲女人天堂av| 一本一道精品欧美中文字幕| 亚洲国产中文字幕| 影音先锋制服丝袜| 盗摄精品av一区二区三区| 久草青青在线观看| 欧美成人综合| 日韩激情视频| 国产精品男女| 亚洲www在线观看| 亚洲精品福利电影| 欧美裸身视频免费观看| 国产永久av在线| 欧美tickling网站挠脚心| 亚洲色成人www永久网站| 亚洲一区av在线| 国产精品国产三级国产传播| 不卡av在线网| 91香蕉视频免费看| 奇米影视一区二区三区| 国产极品尤物在线| 中文字幕亚洲精品乱码| 日本精品二区| 秋霞综合在线视频| 97netav| 国产精品久久久久久妇女| 欧美韩国理论所午夜片917电影| 天天影视久久综合| 国产一区二区三区直播精品电影| 日韩一卡二卡在线| 日韩一区二区三| 国产精品国产一区二区三区四区 | 久久男人天堂| 欧美精品日韩三级| 黄色小网站在线观看| 亚洲三级av在线| 香港三日本三级少妇66| 日韩美女一区二区三区四区| 亚洲一级特黄毛片| 欧美午夜不卡在线观看免费| 久久亚洲天堂网| 亚洲国产综合视频在线观看| 麻豆疯狂做受xxxx高潮视频| 亚洲女人****多毛耸耸8| 自拍偷拍视频亚洲| 久久久久久久久久久99999| 中文文字幕文字幕高清| caoporen国产精品视频| 丝袜熟女一区二区三区| 成人一级片在线观看| 性猛交╳xxx乱大交| 国产精品一区二区视频| 日本亚洲一区二区三区| 国产一区在线精品| 97免费公开视频| 国产成人啪免费观看软件| 免费看的av网站| 岛国av在线一区| 久久久久亚洲AV成人网人人小说| 国产成人精品免费网站| 欧美性猛交乱大交| 成人午夜视频福利| japanese在线观看| 久久伊99综合婷婷久久伊| 美女爆乳18禁www久久久久久| 久久久久久久性| 美女100%露胸无遮挡| 国产精品久久久久一区二区三区 | 久久要要av| 久久最新免费视频| 欧美三区视频| 1024av视频| 石原莉奈在线亚洲二区| 天堂一区在线观看| 国产老女人精品毛片久久| 三上悠亚 电影| jlzzjlzz国产精品久久| 日韩人妻无码一区二区三区| 久久久久久麻豆| 永久av免费网站| 亚洲小说欧美激情另类| 精品美女久久久久| 欧美性色欧美a在线播放| 国产精品热久久| 精品少妇一区二区三区视频免付费| 天堂资源最新在线| 亚洲夜晚福利在线观看| h片在线观看网站| 91精品国产91久久久久久吃药| 吉吉日韩欧美| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 蜜桃精品噜噜噜成人av| 亚洲资源在线网| 亚洲国产免费| 超碰在线97免费| 国产福利精品一区| www.av欧美| 亚洲欧美色综合| 天天干天天色综合| 日韩丝袜情趣美女图片| 国产在线一二三| 欧美激情第一页xxx| 日韩av首页| 999国产视频| 欧美美女视频| 欧美人成在线观看| 久久精品国产77777蜜臀| 在线视频 日韩| 亚洲人成小说网站色在线 | 在线视频精品| 污视频网址在线观看| 91丝袜高跟美女视频| 久久国产精品国语对白| 91国偷自产一区二区三区成为亚洲经典 | 欧美成人精品一区二区男人看| 久久久久久久久久国产| 国产成人77亚洲精品www| 狠狠色噜噜狠狠狠狠色吗综合| 四季av在线一区二区三区 | 精品国产视频在线观看| 日本高清免费不卡视频| 日韩中文字幕影院| 九九九久久国产免费| 久久亚洲精品爱爱| 久久综合九色欧美狠狠| 狠色狠色综合久久| 亚洲一区二区三区三州| 国产精品久久久久久久久晋中 | 精品日韩av| 亚洲综合精品伊人久久| 四季av在线一区二区三区| 欧美午夜性生活| 99久久精品情趣| 国产在线视频99| 欧美一区二区私人影院日本| 成年网站在线| 国产精品91久久| 国产综合久久久| 粉嫩虎白女毛片人体| 99在线精品观看| 日韩精品一区二区在线播放| 欧美成人三级电影在线| 在线三级电影| 99se婷婷在线视频观看| 欧美在线不卡| 国产黄色一区二区三区| 18欧美亚洲精品| 国产精品久久久久久久久久久久久久久久久久 | 日本xxxx人| 久久人91精品久久久久久不卡| 一区二区三区视频免费视频观看网站| 吴梦梦av在线| 国产一区二区三区精品视频| 日韩在线一卡二卡| 91麻豆精品国产91久久久久久| 免费大片在线观看www| 国产精品直播网红| 99精品美女| 91在线第一页| 亚洲一区在线视频| 丰满人妻一区二区三区免费视频 | 激情综合色综合久久综合| 国产美女高潮视频| 日韩精品一区二区三区中文不卡| 日本在线视频www鲁啊鲁| www日韩av| 一本色道久久综合一区| 国产精品jizz| 欧美在线免费观看亚洲| 男人的天堂在线视频免费观看| 成人av在线天堂| 亚洲性人人天天夜夜摸| 亚洲一区二区三区综合| 欧美日韩在线免费观看| а天堂8中文最新版在线官网| 国产中文日韩欧美| 欧美精品99| 51调教丨国产调教视频| 欧美系列一区二区| 中文字幕在线三区| 国产一区二区三区四区五区在线 | 国产精品久久久久久久7电影| 99久久精品网站| 亚洲性图第一页| 一本色道亚洲精品aⅴ| 天堂地址在线www| 国产精品初高中精品久久| 欧美在线综合| 182在线观看视频| 亚洲精品久久久久久下一站| 在线一区视频观看| 精品无码av无码免费专区| 久久久亚洲高清| 国产视频一区二区三| 68精品国产免费久久久久久婷婷 | 99精品视频在线观看| 中文在线字幕免费观| 欧美激情亚洲精品| 精品国产成人| 国产综合内射日韩久| 欧美性一二三区| heyzo高清国产精品| 亚洲不卡1区| 国产不卡在线一区| 亚洲无码久久久久| 欧洲成人在线观看|