我需要将数据帧转换为列表,并且我的其中一列是datetime64类型,但是当我在数据帧中应用values.tolist()时,它将转换为Timestamp,并且我希望它是datetime.date.
此数据框是从以前阅读过的Google表格中获得的:
def get_dataframe_from_sheet(spreadsheet_id, sheet_name, sheet_range):
range_name = '{}!{}'.format(sheet_name, sheet_range)
result = service.spreadsheets().values().get(
spreadsheetId=spreadsheet_id, range=range_name).execute()
values = result.get('values', [])
col_names = values.pop(0)
df = pd.DataFrame(values, columns=col_names)
for col in col_names:
if col in ('forecast_month'):
df[col] = pd.to_datetime(df[col], infer_datetime_format=True)
df[col] = df.apply()
else:
df[col] = pd.to_numeric(df[col], errors='coerce')
return df
short_term_df = get_dataframe_from_sheet(SHORT_TERM_SPREADSHEET_ID, SHEET_NAME, COLUMNS)
但是,当我应用以下内容时:
LIST__SHORT_TERM_FORECAST_SEASON_ADJ_OCC = short_term_df[base_columns + ['season_adj_occ']].values.tolist()
列Forecast_month的值属于Timestamp类型,我需要datetime.date.我该如何实现?我已经阅读了几个问题及其答案,但看来它们无法正常工作.
例:
这是我从函数get_dataframe_from_sheet得到的:
property_id beds forecast_month rent_growth baseline_occ \
0 329 1 2017-02-01 0.02 0.953623
1 329 1 2017-03-01 0.02 0.953623
2 329 1 2017-04-01 0.02 0.953623
3 329 1 2017-05-01 0.02 0.953623
4 329 1 2017-06-01 0.02 0.953623
5 329 1 2017-07-01 0.02 0.953623
6 329 1 2017-08-01 0.02 0.953623
7 329 1 2017-09-01 0.02 0.953623
8 329 1 2017-10-01 0.02 0.953623
9 329 1 2017-11-01 0.02 0.953623
10 329 1 2017-12-01 0.02 0.953623
11 329 1 2018-01-01 0.02 0.953623
12 329 1 2018-02-01 0.02 0.953623
13 329 1 2018-03-01 0.02 0.953623
14 329 1 2018-04-01 0.02 0.953623
15 329 1 2018-05-01 0.02 0.953623
16 329 1 2018-06-01 0.02 0.953623
17 329 1 2018-07-01 0.02 0.953623
18 329 1 2018-08-01 0.02 0.953623
19 329 1 2018-09-01 0.02 0.953623
20 329 1 2018-10-01 0.02 0.953623
21 329 1 2018-11-01 0.02 0.953623
22 329 1 2018-12-01 0.02 0.953623
这是当我应用.values.tolist()时:
[[329,
1,
Timestamp('2017-02-01 00:00:00'),
0.02,
0.95362261,
0.9927,
1.0048,
0.9581999984999999,
0.082725,
0.082725,
0.0016545000000000002],
[329,
1,
Timestamp('2017-03-01 00:00:00'),
0.02,
0.95362261,
1.0006,
1.004,
0.9574371004000001,
0.08338333332999999,
0.1661083333,
0.003322166667], ...
]
解决方法:
尝试这个:
df['forecast_month_alt'] = df['forecast_month'].dt.date
标签:pandas,datetime,python 来源: https://codeday.me/bug/20191111/2018400.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。