Можно использовать только метод доступа .dt со значениями типа datetime - PullRequest
0 голосов
/ 21 июня 2019

Когда я пытаюсь преобразовать строку в datetime, я сталкиваюсь с некоторыми проблемами.

testdata['pe']
Out[69]: 
0     2019-09-26
1     2019-10-31
2     2019-08-28
3     2019-06-20
4     2019-09-30
5     2019-07-22
6     2019-07-31
7     2019-08-30
8     2019-07-29
9     2019-06-28
10    2019-11-20
Name: prd_exp_dt, dtype: object

Когда я это сделал, testdata.pe=testdata.pe.dt.strftime('%Y%M'), я получаю эту ошибку:

Can only use .dt accessor with datetimelike values

Пытался сделать ошибки: "corerce", например:

pandas.to_datetime(testdata['prd_exp_dt'],errors = 'coerce',format = '%Y%M')
Out[68]: 
0    NaT
1    NaT
2    NaT
3    NaT
4    NaT
5    NaT
6    NaT
7    NaT
8    NaT
9    NaT
10   NaT
Name: prd_exp_dt, dtype: datetime64[ns]

Нужны некоторые рекомендации по этому вопросу.

1 Ответ

2 голосов
/ 21 июня 2019

Используйте формат '%Y-%m-%d' и используйте .dt.strftime("%Y%m")

Пример:

import pandas as pd
testdata['prd_exp_dt'] = pd.to_datetime(testdata['prd_exp_dt'] ,errors = 'coerce',format = '%Y-%m-%d').dt.strftime("%Y%m")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...