Мой код на Python довольно прост.Я выполняю SQL-запрос, который дает мне значение столбца datetime, когда файл был зафиксирован.В конце я хочу получить совокупное число подтверждений по месяцам, например,
2017-05 | 2
2017-12 | 1
и т. Д.
filename = 'myFile'
query = ("select date "
"from mytable where branch like %s and repository like %s "
"and filename like %s ")
cursor = churn_db_connection.get_connection_cursor()
cursor.execute(query, (branch, repository,filename,))
dt = []
for (date) in cursor:
dt.append(date[0])
cursor.close()
file1series = pd.DataFrame({
filename: dt
})
file1series[filename] = pd.to_datetime(file1series[filename])
print(file1series.dtypes)
print(file1series.head())
g = file1series[filename].groupby(pd.Grouper(freq="M")) # This line throws the error
print(g.head())
---- вывод для операторов печати -----.
myFile datetime64[ns]
dtype: object
myFile
0 2018-04-06 14:00:08
1 2017-03-15 00:51:20
2 2017-12-07 05:38:22
3 2017-05-12 16:40:05
4 2017-05-03 10:13:47
Это ошибка
TypeError Traceback (most recent call last)
<ipython-input-70-6d36509ffb53> in <module>
43 print(file1series.dtypes)
44 print(file1series.head())
---> 45 g = file1series[filename].groupby(pd.Grouper(freq="M"))
46 print(g.head())
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/generic.py in groupby(self, by, axis, level, as_index, sort, group_keys, squeeze, observed, **kwargs)
6663 return groupby(self, by=by, axis=axis, level=level, as_index=as_index,
6664 sort=sort, group_keys=group_keys, squeeze=squeeze,
-> 6665 observed=observed, **kwargs)
6666
6667 def asfreq(self, freq, method=None, how=None, normalize=False,
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/groupby/groupby.py in groupby(obj, by, **kwds)
2150 raise TypeError('invalid type: %s' % type(obj))
2151
-> 2152 return klass(obj, by, **kwds)
2153
2154
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/groupby/groupby.py in __init__(self, obj, keys, axis, level, grouper, exclusions, selection, as_index, sort, group_keys, squeeze, observed, **kwargs)
597 sort=sort,
598 observed=observed,
--> 599 mutated=self.mutated)
600
601 self.obj = obj
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/groupby/groupby.py in _get_grouper(obj, key, axis, level, sort, observed, mutated, validate)
3187 # a passed-in Grouper, directly convert
3188 if isinstance(key, Grouper):
-> 3189 binner, grouper, obj = key._get_grouper(obj, validate=False)
3190 if key.key is None:
3191 return grouper, [], obj
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/resample.py in _get_grouper(self, obj, validate)
1278 def _get_grouper(self, obj, validate=True):
1279 # create the resampler and return our binner
-> 1280 r = self._get_resampler(obj)
1281 r._set_binner()
1282 return r.binner, r.grouper, r.obj
~/Documents/proj/venv/lib/python3.7/site-packages/pandas/core/resample.py in _get_resampler(self, obj, kind)
1274 raise TypeError("Only valid with DatetimeIndex, "
1275 "TimedeltaIndex or PeriodIndex, "
-> 1276 "but got an instance of %r" % type(ax).__name__)
1277
1278 def _get_grouper(self, obj, validate=True):
TypeError: Only valid with DatetimeIndex, TimedeltaIndex or PeriodIndex, but got an instance of 'RangeIndex'
Я уже пробовал просматривать страницы SOF и пробовал все, но эта ошибка сохраняется.Может быть, это простая вещь, которую я скучаю.Пожалуйста, сообщите