У меня есть фрагмент кода, который извлекает год, месяц, неделю из даты. Год и месяц работают, но год-месяц и неделя возвращают ошибку, подобную приведенной ниже:
AttributeError: 'datetime.datetime' object has no attribute 'week'
Я импортировал библиотеку вот так:
import datetime
и вызвал столбец dt, используя col.dt.year, col.dt.month, col.dt.to_period ('M'), col.dt.week.
Первые 2 работают, а последние 2 - нет. После поиска похожих вопросов я все еще не мог запустить его. Я использую панды 0.23.4. Спасибо за любую помощь.
Я понял, что проблема в том, что это тип vDDD, а не дата и время, что связано с некоторыми известными проблемами при извлечении временных интервалов, а код требует чтения ical. Я попытался объединить ymd в правильный объект dt df ['dt'] = pd.to_datetime (dict (year = df ['Year'], month = df ['Month'], day = df ['Day']) )), а затем запустите df ['dt']. dt.week (), но теперь он возвращает TypeError: объект 'Series' не вызывается
попробуйте df['dt'].dt.week вместо df['dt'].dt.week()
это сработало! благодаря.






По Как получить номер недели в Python?:
>>> import datetime
>>> datetime.date(2010, 6, 16).isocalendar()[1]
24
Адаптирован к вашему коду (при условии, что col.dt - это datetime),
col.dt.isocalendar()[1]
почти уверен, что col.dt - это pandas.Series.dt
Я думаю ты прав; если pandas.Series.dt просто подчиняется datetime.datetime под капотом, то isocalendar() все равно будет работать; в противном случае я предполагаю, что потребуется явный вызов to_pydatetime() ...
Вам необходимо предоставить код. Без него мы можем только сказать, что вы ссылаетесь на
col.dtкак наdatetime.datetime, как указано в ошибке.