Проблема заключается в преобразовании в даты и время, необходимо установить формат или dayfirst=True
, потому что DD/MM/YY
:
df1['Date'] = pd.to_datetime(df1['Date'], format='%d/%m/%y')
Или:
df1['Date'] = pd.to_datetime(df1['Date'], dayfirst=True)
И если необходимо построить график по названиям месяцевиспользуйте:
df1['Date'] = pd.to_datetime(df1['Date'], format='%d/%m/%y').dt.month_name()
#alternative
#df1['Date'] = pd.to_datetime(df1['Date'], format='%d/%m/%y').dt.strftime('%B')
df1.groupby('Date')['Value'].count().plot(kind = 'bar')
data:image/s3,"s3://crabby-images/3d85d/3d85db0c973ae683171af60be7b26d18832be595" alt="g"
При необходимости правильного заказа месяцев:
months = ['January','February','March','April','May','June','July','August',
'September','October','November','December']
df1['Date'] = pd.Categorical(df1['Date'], categories=months, ordered=True)
df1.groupby('Date')['Value'].count().plot(kind = 'bar')
data:image/s3,"s3://crabby-images/135ce/135ce43864128665c643694e9f032e4b832d9265" alt="g1"
Если хотите отфильтровать 0
значения:
df1.groupby('Date')['Value'].count().pipe(lambda x: x[x != 0]).plot(kind = 'bar')
data:image/s3,"s3://crabby-images/ceb5e/ceb5e3b551ae32afb796f96749911a755855f56c" alt="g2"
Спасибо @asongtoruin за другую идею:
df1['Date'] = pd.to_datetime(df1['Date'], format='%d/%m/%y')
#if necessary sorting datetimes
#df1 = df1.sort_values('Date')
df1['month_name'] = df1['Date'].dt.month_name()
df1.groupby('Date').agg({'Value': 'count', 'month_name': 'first'})
.plot(x='month_name', y='Value', kind='bar')