Проблемы с подготовкой участка горного хребта в Seaborn - PullRequest
0 голосов
/ 07 марта 2019

У меня есть dataframe hour_dist, который показывает час, в течение которого клиент показывался в определенном месте.

hour_dist.sample(5)

        Location            Hour
88131   1233000000000000    21
111274  1233000000000000    0
81126   2991000000000000    23
104181  1232000000000000    22
55719   1232000000000000    15

Я пытаюсь нанести эти данные на Seaborn для визуализации грядового графика (https://seaborn.pydata.org/examples/kde_ridgeplot.html).

По сути, он должен отображать распределение часов по каждому местоположению. Вотпример того, как это выглядит:

enter image description here

С помощью hour_dist я безуспешно пытался нанести на карту местоположения на оси y и часпо оси х.

1 Ответ

0 голосов
/ 07 марта 2019

Для меня работает изменение g на Location и x на Hour, но если много уникальных значений Location, то должно быть много графиков с реальными данными:

import numpy as np
import pandas as pd
import seaborn as sns

import matplotlib.pyplot as plt
sns.set(style="white", rc={"axes.facecolor": (0, 0, 0, 0)})


# Initialize the FacetGrid object
pal = sns.cubehelix_palette(10, rot=-.25, light=.7)
g = sns.FacetGrid(df, row="Location", hue="Location", aspect=15, height=.5, palette=pal)

Еслинужен график в процентах:

#df['pct'] = df['Location'].div(df.groupby('Hour')['Location'].transform('sum'))
#g = sns.FacetGrid(df, row="pct", hue="pct", aspect=15, height=.5, palette=pal)


# Draw the densities in a few steps
g.map(sns.kdeplot, "Hour", clip_on=False, shade=True, alpha=1, lw=1.5, bw=.2)
g.map(sns.kdeplot, "Hour", clip_on=False, color="w", lw=2, bw=.2)
g.map(plt.axhline, y=0, lw=2, clip_on=False)


# Define and use a simple function to label the plot in axes coordinates
def label(x, color, label):
    ax = plt.gca()
    ax.text(0, .2, label, fontweight="bold", color=color,
            ha="left", va="center", transform=ax.transAxes)


g.map(label, "Hour")

# Set the subplots to overlap
g.fig.subplots_adjust(hspace=-.25)

# Remove axes details that don't play well with overlap
g.set_titles("")
g.set(yticks=[])
g.despine(bottom=True, left=True)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...