文字列をデータフレームから日時に変換したい。
dfx = df.ix[:,'a']
dfx = pd.to_datetime(dfx)
ただし、次のエラーが発生します。
ValueError:日が月の範囲外です
誰か助けてもらえますか?
Datetimeの形式がdayfirst=True
の場合、パラメータto_datetime
を 30-01-2016
に追加するのに役立ちます。
dfx = df.ix[:,'a']
dfx = pd.to_datetime(dfx, dayfirst=True)
より一般的なのは、パラメータを使用する format
with errors='coerce'
で値を他のformat
からNaN
に置き換えることです:
dfx = '30-01-2016'
dfx = pd.to_datetime(dfx, format='%d-%m-%Y', errors='coerce')
print (dfx)
2016-01-30 00:00:00
サンプル:
dfx = pd.Series(['30-01-2016', '15-09-2015', '40-09-2016'])
print (dfx)
0 30-01-2016
1 15-09-2015
2 40-09-2016
dtype: object
dfx = pd.to_datetime(dfx, format='%d-%m-%Y', errors='coerce')
print (dfx)
0 2016-01-30
1 2015-09-15
2 NaT
dtype: datetime64[ns]
形式が標準の場合(例:01-30-2016
または01-30-2016
)、errors='coerce'
のみを追加します。
dfx = pd.Series(['01-30-2016', '09-15-2015', '09-40-2016'])
print (dfx)
0 01-30-2016
1 09-15-2015
2 09-40-2016
dtype: object
dfx = pd.to_datetime(dfx, errors='coerce')
print (dfx)
0 2016-01-30
1 2015-09-15
2 NaT
dtype: datetime64[ns]