проблема с вставкой вертикальных линий в указанные c дни в дату matplotlib - PullRequest
0 голосов
/ 17 июня 2020

Я хочу вставить в свой график несколько вертикальных пунктирных линий. Я использую следующий код и сталкиваюсь с ошибкой «ValueError: минимальный предел просмотра -34758.04999999988 меньше 1 и является недопустимым значением даты Matplotlib. Это часто происходит, если вы передаете значение, отличное от datetime, на ось, которая имеет единицы datetime» . Вот образец моих данных.

   Date        M      
2013-03-13  0.727195
2013-03-14  0.727195
2013-03-15  0.727195
2013-03-16  0.727195
2013-03-17  0.727195
...              ...
2018-11-12  0.115674
2018-11-13 -0.427214
2018-11-14 -0.389715
2018-11-15  0.427149
2018-11-16 -0.416864

[2075 rows x 1 columns]

, а это мой код

import pandas as pd
from datetime import datetime, timedelta
from matplotlib import pyplot as plt
from matplotlib import dates as mpl_dates

data=pd.read_excel('ff.xlsx')
data['Date']=pd.to_datetime(data['Date'], format="%Y-%m-%d")
date = data['Date']
amount = data['M']
data.set_index('Date', inplace=True, drop=True)
plt.plot(date,amount, color='blue')
ax = plt.axes()        
ax.yaxis.grid()
plt.ylabel('dvv percentage')
xposition = [2015-11-11, 2014-11-11]
for xc in xposition:
 plt.axvline(x=xc, color='k', linestyle='--')

plt.show()

1 Ответ

0 голосов
/ 17 июня 2020

это должно работать:

from matplotlib import pyplot as plt
import pandas as pd

# example df:
df = pd.DataFrame({'Date':['2013-03-13','2015-03-14','2019-03-15'],
                   'M':[0.727195, -0.727195, 0.669195]})
# ensure datetime:
df['Date'] = pd.to_datetime(df['Date'])


ax = plt.plot(df.Date, df.M, color='blue')
ax = plt.axes()
ax.yaxis.grid()
plt.ylabel('dvv percentage')

# vertical line position as datetime dtype:
xposition = pd.to_datetime(['2015-11-11', '2014-11-11'])
for xc in xposition:
    ax.axvline(x=xc, color='k', linestyle='--')

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