gpt4 book ai didi

python - 将 .values.tolist() 应用于数据框时将 datetime64 列转换为 datetime.date

转载 作者:太空宇宙 更新时间:2023-11-03 15:53:56 25 4
gpt4 key购买 nike

我需要将数据框转换为列表,其中一列的类型为 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

关于python - 将 .values.tolist() 应用于数据框时将 datetime64 列转换为 datetime.date,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44764589/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com