Что касается второго вопроса, вы можете использовать matplotlib.dates
локаторы и форматеры.Они отлично работают в случае hist
.
import matplotlib.pyplot as plt
plt.rcParams['axes.axisbelow'] = True
import matplotlib.dates as dates
import numpy as np; np.random.seed(42)
import pandas as pd
objDate = dates.num2date(np.random.normal(735700, 300, 700))
ser = pd.Series(objDate)
ax = ser.hist(cumulative=True, density=1, bins=500, histtype='step', linewidth=2)
ax.xaxis.set_major_locator(dates.MonthLocator([1,7]))
ax.xaxis.set_major_formatter(dates.DateFormatter("%m/%y"))
plt.setp(ax.get_xticklabels(), rotation=60)
plt.show()
![enter image description here](https://i.stack.imgur.com/Fytjx.png)
Для первого вопроса это не просто, потому что matplotlib всегда предполагаетполная ось, которая будет отмечена.Решением было бы создать подкласс используемого локатора и позволить ему принимать ограничительные аргументы.
from datetime import datetime
import matplotlib.pyplot as plt
plt.rcParams['axes.axisbelow'] = True
import matplotlib.dates as dates
import numpy as np; np.random.seed(42)
import pandas as pd
objDate = dates.num2date(np.random.normal(735700, 300, 700))
ser = pd.Series(objDate)
ax = ser.hist(cumulative=True, density=1, bins=500, histtype='step', linewidth=2)
class RestrictedLocator(dates.MonthLocator):
def __init__(self, dmin=None, dmax=None, **kw):
self.dmin = dmin
self.dmax = dmax
dates.MonthLocator.__init__(self, **kw)
def __call__(self):
try:
dmin, dmax = self.viewlim_to_dt()
except ValueError:
return []
self.dmin = self.dmin.replace(tzinfo=dmin.tzinfo)
self.dmax = self.dmax.replace(tzinfo=dmin.tzinfo)
dmin = np.max([dmin, self.dmin])
dmax = np.min([dmax, self.dmax])
return self.tick_values(dmin, dmax)
loc = RestrictedLocator(dmin=datetime(2015,1,1),
dmax = datetime(2017,12,31),
bymonth=[1,7])
ax.xaxis.set_major_locator(loc)
ax.xaxis.set_major_formatter(dates.DateFormatter("%m/%y"))
plt.setp(ax.get_xticklabels(), rotation=60)
plt.show()
![enter image description here](https://i.stack.imgur.com/NKkSi.png)