- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要将数据框转换为列表,其中一列的类型为 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/
数据框有一个字符串类型的日期列 '2017-01-01' 它被转换为 DateType() df = df.withColumn('date', col('date_string').cast(Dat
这个问题在这里已经有了答案: What is "x && foo()"? (5 个答案) 关闭 8 年前。 我在 bootstrap-datepicker.js 文件中遇到过这个。 作者在_setD
我有一个数据库 utc 字符串,我正在传递到 Date(attrs.endDate),然后通过 new Date() 减去当前的 utc 日期,但我无法得到它来为我提供 2 个 utc 日期的正确差异
这个问题在这里已经有了答案: how to determine if 2 dates object equals each other? [duplicate] (3 个答案) 关闭 6 年前。 我
这个问题已经有答案了: How can I convert "/Date(1399739515000)/" into date format in JavaScript? (3 个回答) 已关闭 8
根据MDN ,我们只能将以下类型的参数传递给 Date 构造函数: new Date(); new Date(value); // Unix timestamp new Date(dateString
我从表中获取所有项目: endDate >= 现在 endDate 为 NULL published 等于 1。 这是我所拥有的,但它给了我 0 个项目: $items = Items::orderB
此查询需要很长时间才能完成。当我将 WHERE 子句设置为 new_dl >= '2014-01-01' 时,查询大约需要 6 分钟才能浏览大约 3 个月的数据。现在不知道为什么这个应该从 12 个月
我有一个正在为项目开发的小型 Java 程序,它使用 JavaMail 从指定的 URI 中提取用户的收件箱,然后开始处理消息。 在 Outlook 中,属性菜单中有一个功能可以设置邮件的到期日期,它
我想在获取 Date.getHours()、Date.getMinutes() 和 Date.getSeconds() 的值后格式化输出>. 这是一条漫长的路: var dt = new Date()
我发现java.text.DateFormat有两种格式化日期的方法。一种是采用 Date 参数,另一种是采用 Object 参数。我检查了DateFormat源代码,似乎他们调用了不同的内部方法。
我有两个对象,p4 和 p5,它们都具有 Date 属性。在某些时候,构造函数工作正常: p4.setClickDate(new Date(System.currentTimeMillis() - 8
我是使用 Sequelize 和 Node.js 的新手,但我的代码中存在日期比较问题。 User.findOne({ where: { resetToken: passwordToken,
我正在使用一个名为 fullcalendar 的 jquery 日历。当用户单击某一天时,他们将被发送到另一个页面以创建该天的事件。单击的日期作为 date 提供。然后通过下面的函数运行将其转换为 U
我有一个列表列表,每个列表中都有整数值,代表 8 年期间的日期。 dates = [[2014, 11, 14], [2014, 11, 13], ....., [2013, 12, 01]
我有两个表: 首先是TimeValues(示例) time | value 12/28/18 | 5.6 01/03/19 | 5.6 01/04/19 | 5.6 01/09/19 | 5.
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
像这样实例化的日期对象: new Date("2011-12-13") 返回一个认为自己是星期一的日期对象: Date {Mon Dec 12 2011 16:00:00 GMT-0800 (PST)
我需要选择入住日期和退房日期在指定日期范围之间的房价。这些费率根据其条件单独命名。房费取决于所选日期。这是我的代码: rate_eb rate_name rate_starts rat
我有 [Int64:[String:String]] 其中 Int64 是时间戳。如何检测和删除 [String:String] 中的参数之一是 ["name"] = "test" 并重复多次的同一天
我是一名优秀的程序员,十分优秀!