在默认情况下双变量关系图是散点图与直方图组合的联合直方图,可以通过设置kind来改变联合直方图。
案例代码已上传:Github地址
import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 tips = sns.load_dataset("tips") """ 案例1: 绘制散点图,边缘为直方图:联合直方图 """ sns.jointplot(x="total_bill", y="tip", data=tips) plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 tips = sns.load_dataset("tips") """ 案例2: 在联合添加回归和核密度拟合 """ sns.jointplot("total_bill", "tip", data=tips, kind="reg") plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 tips = sns.load_dataset("tips") """ 案例3: 使用六边形点代替联合直方图中的圆形散点 """ sns.jointplot("total_bill", "tip", data=tips, kind="hex") plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 iris = sns.load_dataset("iris") """ 案例4: 将散点图和直方图均替换为核密度估计 """ sns.jointplot("sepal_width", "petal_length", data=iris, kind="kde", space=0, color="g") plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 iris = sns.load_dataset("iris") """ 案例5: 绘制散点图,并添加联合密度估计 """ g = (sns.jointplot("sepal_length", "sepal_width", data=iris, color="k") .plot_joint(sns.kdeplot, zorder=0, n_levels=6)) plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) """ 案例6: 随机生成300个(x,y)二维数据,并指定x,y轴 """ x, y = np.random.randn(2, 300) (sns.jointplot(x, y, kind="hex").set_axis_labels("x", "y")) plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 tips = sns.load_dataset("tips") """ 案例7: 通过指定height来设置图的大小 """ sns.jointplot("total_bill", "tip", data=tips, height=5, ratio=3, color="g") plt.show() import numpy as np import pandas as pd import seaborn as sns import matplotlib.pyplot as plt #设置风格样式 sns.set(style="white", color_codes=True) # np.random.seed(num),指定了num则表示生成的随机数是可预测的 np.random.seed(0) # 构建数据 tips = sns.load_dataset("tips") """ 案例8: 其他一些参数的设置效果 """ sns.jointplot("petal_length", "sepal_length", data=iris, marginal_kws=dict(bins=15, rug=True), annot_kws=dict(stat="r"), s=40, edgecolor="w", linewidth=1) plt.show()上述案例代码已上传:Github地址 Github地址https://github.com/Vambooo/SeabornCN
更多技术干货在公众号:数据分析与可视化学研社
