Иногда лучше обновить ваших текущих пакетов разработки. Так как на вашем virtual-env
установлен локальный matplotlib
. После активации источника обновите matplotlib
.
Для этого откройте terminal
или command prompt
с административными привилегиями и попробуйте обновить pip
и matplotlib
версии, используя следующие Команды:
python -m pip install --upgrade pip
python -m pip install --upgrade matplotlib
С другой стороны, используя matplotlib
, вы можете get или установить текущие местоположения галочек и метки любой из осей (то есть x-axis
или y-axis
).
Я приведу вам очень простой пример ваших данных данные для построения в порядке вдоль обеих осей. Чтобы сохранить заказы вдоль axes
, вы можете просто использовать:
Вы можете использовать эту технику для решения вашей проблемы с обновлением matplotlib
и без него. Специально для указанной вами версии matplotlib==2.1.1
.
import matplotlib.pyplot as plt
x_axis_values = ['(-68.18100000000001, 89.754]', '(89.754, 130.42]', '(130.42, 165.601]', '(165.601, 205.456]',
'(205.456, 371.968]']
y_axis_values = ['(-0.123, 0.749]', '(0.749, 0.922]', '(0.922, 1.068]', '(1.068, 1.253]', '(1.253, 2.14]']
# Try to sort the values, before passing to [xticks, yticks]
# or in which order, you want them along axes
plt.xticks(ticks=range(len(x_axis_values)), labels=x_axis_values)
plt.yticks(ticks=range(len(y_axis_values)), labels=y_axis_values)
# plt.scatter(x_axis_values, y_axis_values)
plt.xlabel('Values')
plt.ylabel('Indices')
plt.show()
Вот вывод этого простого примера. Вы можете увидеть значения вдоль x-axis
и y-axis
. Цель данного рисунка состоит только в том, чтобы указать values
вместе с обоими axes
:
Для данного кода: Я обновил некоторые из ваших кодов следующим образом:
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.colors
import numpy as np
n_tile = 5
np.random.seed(0)
x = np.random.normal(150, 70, 3000, )
y = np.random.normal(1, 0.3, 3000)
r = np.random.normal(0.4, 0.1, 3000)
plot_data = pd.DataFrame({
'x': x,
'y': y,
'r': r
})
plot_data['x_group'] = pd.qcut(plot_data['x'], n_tile, duplicates='drop')
plot_data['y_group'] = pd.qcut(plot_data['y'], n_tile, duplicates='drop')
plot_data_grouped = plot_data.groupby(['x_group', 'y_group'], as_index=False).agg({'r': ['mean', 'count']})
plot_data_grouped.columns = ['x', 'y', 'mean', 'count']
cmap = plt.cm.rainbow
norm = matplotlib.colors.Normalize(vmin=0, vmax=1)
########################################################
########## Updated Portion of the Code ################
x_axis_values = [str(x) for x in plot_data_grouped['x']]
y_axis_values = [str(x) for x in plot_data_grouped['y']]
plt.figure(figsize=(10, 10))
# Unique Values have only length == 5
plt.xticks(ticks=range(5), labels=sorted(np.unique(x_axis_values)))
plt.yticks(ticks=range(5), labels=sorted(np.unique(y_axis_values)))
plt.scatter(x=x_axis_values,
y=y_axis_values,
s=plot_data_grouped["count"],
c=plot_data_grouped['mean'], cmap="RdYlGn", edgecolors="black")
plt.show()
########################################################
Теперь вы можете видеть, что вывод соответствует: