2017-08-29 146 views
1

與時間戳轉換一個熊貓系列爲字符串是相當簡單的,例如:時間戳轉換大熊貓據幀爲String

dateSfromPandas = dfC['Date324'].dt.strftime('%Y/%m/%d') 

但是你如何轉換一個大的熊貓數據幀的所有列是日期。以上不工作:

dateSfromPandas = dfC.dt.strftime('%Y/%m/%d') 

回答

1

您可以使用apply

dateSfromPandas = dfC.apply(lambda x: x.dt.strftime('%Y/%m/%d')) 

樣品:

dfC = pd.DataFrame({'a': pd.date_range('2016-01-01', periods=10), 
        'b': pd.date_range('2016-10-04', periods=10), 
        'c': pd.date_range('2016-05-06', periods=10)}) 
print (dfC) 
      a   b   c 
0 2016-01-01 2016-10-04 2016-05-06 
1 2016-01-02 2016-10-05 2016-05-07 
2 2016-01-03 2016-10-06 2016-05-08 
3 2016-01-04 2016-10-07 2016-05-09 
4 2016-01-05 2016-10-08 2016-05-10 
5 2016-01-06 2016-10-09 2016-05-11 
6 2016-01-07 2016-10-10 2016-05-12 
7 2016-01-08 2016-10-11 2016-05-13 
8 2016-01-09 2016-10-12 2016-05-14 
9 2016-01-10 2016-10-13 2016-05-15 

dateSfromPandas = dfC.apply(lambda x: x.dt.strftime('%Y/%m/%d')) 
print (dateSfromPandas) 
      a   b   c 
0 2016/01/01 2016/10/04 2016/05/06 
1 2016/01/02 2016/10/05 2016/05/07 
2 2016/01/03 2016/10/06 2016/05/08 
3 2016/01/04 2016/10/07 2016/05/09 
4 2016/01/05 2016/10/08 2016/05/10 
5 2016/01/06 2016/10/09 2016/05/11 
6 2016/01/07 2016/10/10 2016/05/12 
7 2016/01/08 2016/10/11 2016/05/13 
8 2016/01/09 2016/10/12 2016/05/14 
9 2016/01/10 2016/10/13 2016/05/15 

如果另一種可能的解決方案要修改原:

for col in dfC: 
    dfC[col] = dfC[col].dt.strftime('%Y/%m/%d') 
print (dfC) 
      a   b   c 
0 2016/01/01 2016/10/04 2016/05/06 
1 2016/01/02 2016/10/05 2016/05/07 
2 2016/01/03 2016/10/06 2016/05/08 
3 2016/01/04 2016/10/07 2016/05/09 
4 2016/01/05 2016/10/08 2016/05/10 
5 2016/01/06 2016/10/09 2016/05/11 
6 2016/01/07 2016/10/10 2016/05/12 
7 2016/01/08 2016/10/11 2016/05/13 
8 2016/01/09 2016/10/12 2016/05/14 
9 2016/01/10 2016/10/13 2016/05/15