热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

pandas如何把时间转成index_pandas将“字符类型的日期列”转化成“时间戳索引(DatetimeIndex)”...

假设目前已经引入了pandas,同时也拥有pandas的DataFrame类型数据。importpandasaspd数据集如下df.head(3)dateopencl

假设目前已经引入了 pandas,同时也拥有 pandas 的 DataFrame 类型数据。import pandas as pd

数据集如下df.head(3)date open close high low volume code

0 2006-12-18 3.905 3.886 3.943 3.867 171180.67 600001

1 2006-12-19 3.886 3.924 3.981 3.867 276799.39 600001

2 2006-12-20 3.934 3.934 3.962 3.809 265653.85 600001

查看每一列的类型df.info()

从结果的第四排可以看见 date 这一列类型是"object",即字符类型。

RangeIndex: 640 entries, 0 to 639

Data columns (total 7 columns):

date 640 non-null object

open 640 non-null float64

close 640 non-null float64

high 640 non-null float64

low 640 non-null float64

volume 640 non-null float64

code 640 non-null object

dtypes: float64(5), object(2)

memory usage: 35.1+ KB

现在的目标是:把 date 这一列用作索引

把 date 用作索引时,类型需要是 DatetimeIndex。

方法1: .to_datetime 和 .set_index

首先,利用 pandas 的to_datetime 方法,把 "date" 列的字符类型数据解析成 datetime 对象。

然后,把 "date" 列用作索引。df['date'] = pd.to_datetime(df['date'])

df.set_index("date", inplace=True)

结果:df.head(3)open close high low volume code

date

2006-12-18 3.905 3.886 3.943 3.867 171180.67 600001

2006-12-19 3.886 3.924 3.981 3.867 276799.39 600001

2006-12-20 3.934 3.934 3.962 3.809 265653.85 600001

查看索引是否成为 DatetimeIndex 类型,可以看见确实已经成功转化类型。df.axes[DatetimeIndex(['2006-12-18', '2006-12-19', '2006-12-20', '2006-12-21',

'2006-12-22', '2006-12-25', '2006-12-26', '2006-12-27',

'2006-12-28', '2006-12-29',

...

'2009-12-02', '2009-12-03', '2009-12-04', '2009-12-07',

'2009-12-08', '2009-12-09', '2009-12-10', '2009-12-11',

'2009-12-14', '2009-12-15'],

dtype='datetime64[ns]', name='date', length=640, freq=None),

Index(['open', 'close', 'high', 'low', 'volume', 'code'], dtype='object')]

方法2: .DatetimeIndex

首先是原始数据。df2.head(3)date open close high low volume code

0 2003-08-01 4.997 4.949 5.016 4.949 20709.15 600002

1 2003-08-04 4.949 5.045 5.054 4.949 23923.35 600002

2 2003-08-05 5.054 5.093 5.131 5.006 35224.00 600002

先把 "date" 列用作索引,然后使用 DatetimeIndex 将字符类型转化成 DateIndex。df2.set_index("date", inplace=True)

这个时候索引还是 object 类型,就是字符串类型。df2.axes[Index(['2003-08-01', '2003-08-04', '2003-08-05', '2003-08-06', '2003-08-07',

'2003-08-08', '2003-08-11', '2003-08-12', '2003-08-13', '2003-08-14',

...

'2006-03-24', '2006-03-27', '2006-03-28', '2006-03-29', '2006-03-30',

'2006-03-31', '2006-04-03', '2006-04-04', '2006-04-05', '2006-04-06'],

dtype='object', name='date', length=640),

Index(['open', 'close', 'high', 'low', 'volume', 'code'], dtype='object')]

将其转化成 DateIndex 类型。df2.index = pd.DatetimeIndex(df.index)

再次查看结果df2.axes

转化成功[DatetimeIndex(['2006-12-18', '2006-12-19', '2006-12-20', '2006-12-21',

'2006-12-22', '2006-12-25', '2006-12-26', '2006-12-27',

'2006-12-28', '2006-12-29',

...

'2009-12-02', '2009-12-03', '2009-12-04', '2009-12-07',

'2009-12-08', '2009-12-09', '2009-12-10', '2009-12-11',

'2009-12-14', '2009-12-15'],

dtype='datetime64[ns]', name='date', length=640, freq=None),

Index(['open', 'close', 'high', 'low', 'volume', 'code'], dtype='object')]

结论:.to_datetime仅转换格式,.DatetimeIndex还能设置为索引

两者在转化格式的功能上效果一样,都可以把字符串对象转换成 datetime 对象。

pd.DatetimeIndex 是把某一列进行转换,同时把该列的数据设置为索引 index。

比如df2.index = pd.DatetimeIndex(df2["date"])

得到一个以 date 作为索引的结果。

.DatetimeIndex 的问题是原来的 date 列数据仍然存在,形成了重复。date open close high low volume code

date

2003-08-01 2003-08-01 4.997 4.949 5.016 4.949 20709.15 600002

2003-08-04 2003-08-04 4.949 5.045 5.054 4.949 23923.35 600002

2003-08-05 2003-08-05 5.054 5.093 5.131 5.006 35224.00 600002

最终还需要把 date 这一列删掉。del df2["date"]

才能得到正常数据open close high low volume code

date

2003-08-01 4.997 4.949 5.016 4.949 20709.15 600002

2003-08-04 4.949 5.045 5.054 4.949 23923.35 600002

2003-08-05 5.054 5.093 5.131 5.006 35224.00 600002



推荐阅读
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • sqlserver动态分区方案例子
    sqlserver动态分区方案例子当我们存储的数据量比较大时,比如超过千万,上亿级别时单纯的使用索引可能效果不明显了,此时我们可以考虑采 ... [详细]
  • 本文探讨了Java中char数据类型的特点,包括其表示范围以及如何处理超出16位字符限制的情况。通过引入代码点和代码单元的概念,详细解释了Java处理增补字符的方法。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细解析了如何使用Python语言在STM32硬件平台上实现高效的编程和快速的应用开发。通过具体的代码示例,展示了Python简洁而强大的特性。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • springMVC JRS303验证 ... [详细]
  • 本文档提供了如何使用C#代码从客户订单中提取产品信息的方法,适用于需要处理和分析产品数据的应用场景。 ... [详细]
  • Microsoft即将发布WPF/E的CTP(Community Technology Preview)和SDK,标志着RIA(Rich Internet Application)技术的新里程碑。更多详情及下载链接请参见MSDN官方页面。 ... [详细]
author-avatar
徐州九七医院沁尿外科1
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有