Формат pd.Interval категорий при построении - PullRequest
0 голосов
/ 05 декабря 2018

У меня есть похожий вопрос, подобный этому: вопрос

Ссылаясь на код из поста выше.

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt




my_list = [1,2,3,4,5,7,8,9,11,23,56,78,3,3,5,7,9,12]

new_list = pd.Series(my_list)

df1 = pd.DataFrame({'Range1':new_list.value_counts().index, 'Range2':new_list.value_counts().values})

df1.sort_values(by=["Range1"],inplace=True)

df2 = df1.groupby(pd.cut(df1["Range1"], [0,1,2,3,4,5,6,7,8,9,10,11,df1['Range1'].max()])).sum()

objects = df2['Range2'].index

y_pos = np.arange(len(df2['Range2'].index))

, но хочу следующую последовательность on x-axis:

Ожидаемый результат:

(00,01] (01,02] (02,03] (03,04]......

Любая помощь в получении ожидаемого результата?

1 Ответ

0 голосов
/ 05 декабря 2018

Это не просто, но выполнимо.Вам нужно будет отформатировать левый и правый интервалы отдельно.

l = df2.index.categories.left.map("{:02d}".format)
r = df2.index.categories.right.map("{:02d}".format)

plt.bar(range(len(df2)), df2['Range2'].values, tick_label='('+l+', '+r+']')
plt.xticks(fontsize=6)

plt.show()

enter image description here

Где,

print('('+l+', '+r+']')
Index(['(00, 01]', '(01, 02]', '(02, 03]', '(03, 04]', '(04, 05]', '(05, 06]',
       '(06, 07]', '(07, 08]', '(08, 09]', '(09, 10]', '(10, 11]', '(11, 78]'],
      dtype='object')

Возможно, у вас естьизменить скобки в зависимости от того, закрыты ли интервалы слева, справа или нет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...