我的编程空间,编程开发者的网络收藏夹
学习永远不晚

pandas.DataFrame中如何提取特定类型dtype的列

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

pandas.DataFrame中如何提取特定类型dtype的列

本篇内容介绍了“pandas.DataFrame中如何提取特定类型dtype的列”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

pandas.DataFrame为每一列保存一个数据类型dtype。

要仅提取(选择)特定数据类型为dtype的列,请使用pandas.DataFrame的select_dtypes()方法。

以带有各种数据类型的列的pandas.DataFrame为例。

import pandas as pddf = pd.DataFrame({'a': [1, 2, 1, 3],                   'b': [0.4, 1.1, 0.1, 0.8],                   'c': ['X', 'Y', 'X', 'Z'],                   'd': [[0, 0], [0, 1], [1, 0], [1, 1]],                   'e': [True, True, False, True]})df['f'] = pd.to_datetime(['2018-01-01', '2018-03-15', '2018-02-20', '2018-03-15'])print(df)#    a    b  c       d      e          f# 0  1  0.4  X  [0, 0]   True 2018-01-01# 1  2  1.1  Y  [0, 1]   True 2018-03-15# 2  1  0.1  X  [1, 0]  False 2018-02-20# 3  3  0.8  Z  [1, 1]   True 2018-03-15print(df.dtypes)# a             int64# b           float64# c            object# d            object# e              bool# f    datetime64[ns]# dtype: object

将描述以下内容。

select_dtypes()的基本用法

  • 指定要提取的类型:参数include

  • 指定要排除的类型:参数exclude

select_dtypes()的基本用法

指定要提取的类型:参数include

在参数include中指定要提取的数据类型dtype。

print(df.select_dtypes(include=int))#    a# 0  1# 1  2# 2  1# 3  3

可以按原样指定作为Python的内置类型提供的那些变量,例如int和float。您可以将“ int”指定为字符串,也可以指定“ int64”(包括确切位数)。 (标准位数取决于环境)

print(df.select_dtypes(include='int'))#    a# 0  1# 1  2# 2  1# 3  3print(df.select_dtypes(include='int64'))#    a# 0  1# 1  2# 2  1# 3  3

当然,当最多包括位数时,除非位数匹配,否则不会选择它。

print(df.select_dtypes(include='int32'))# Empty DataFrame# Columns: []# Index: [0, 1, 2, 3]

列表中可以指定多种数据类型dtype。日期和时间datetime64 [ns]可以由’datetime’指定。

print(df.select_dtypes(include=[int, float, 'datetime']))#    a    b          f# 0  1  0.4 2018-01-01# 1  2  1.1 2018-03-15# 2  1  0.1 2018-02-20# 3  3  0.8 2018-03-15

可以将数字类型(例如int和float)与特殊值“ number”一起指定。

print(df.select_dtypes(include='number'))#    a    b# 0  1  0.4# 1  2  1.1# 2  1  0.1# 3  3  0.8

元素为字符串str类型的列的数据类型dtype是object,但是object列还包含除str外的Python标准内置类型。实际上,数量并不多,但是,如示例中所示,如果有一列的元素为列表类型,请注意,该列也是由include = object提取的。

print(df.select_dtypes(include=object))#    c       d# 0  X  [0, 0]# 1  Y  [0, 1]# 2  X  [1, 0]# 3  Z  [1, 1]print(type(df.at[0, 'c']))# <class 'str'>print(type(df.at[0, 'd']))# <class 'list'>

但是,除非对其进行有意处理,否则字符串str类型以外的对象都不会(可能)成为pandas.DataFrame的元素,因此不必担心太多。

指定要排除的类型:参数exclude

在参数exclude中指定要排除的数据类型dtype。您还可以在列表中指定多个数据类型dtype。

print(df.select_dtypes(exclude='number'))#    c       d      e          f# 0  X  [0, 0]   True 2018-01-01# 1  Y  [0, 1]   True 2018-03-15# 2  X  [1, 0]  False 2018-02-20# 3  Z  [1, 1]   True 2018-03-15print(df.select_dtypes(exclude=[bool, 'datetime']))#    a    b  c       d# 0  1  0.4  X  [0, 0]# 1  2  1.1  Y  [0, 1]# 2  1  0.1  X  [1, 0]# 3  3  0.8  Z  [1, 1]

可以同时指定包含和排除,但是如果指定相同的类型,则会发生错误。

print(df.select_dtypes(include='number', exclude=int))#      b# 0  0.4# 1  1.1# 2  0.1# 3  0.8# print(df.select_dtypes(include=[int, bool], exclude=int))# ValueError: include and exclude overlap on frozenset({<class 'numpy.int64'>})

“pandas.DataFrame中如何提取特定类型dtype的列”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

pandas.DataFrame中如何提取特定类型dtype的列

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

pandas.DataFrame中如何提取特定类型dtype的列

本篇内容介绍了“pandas.DataFrame中如何提取特定类型dtype的列”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!pandas.
2023-07-05

pandas.DataFrame中提取特定类型dtype的列

本文主要介绍了pandas.DataFrame中提取特定类型dtype的列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-02-23

如何限制特定类型的接口{}

问题内容我正在使用 go,并且有一个工厂函数,它根据请求的标识符返回不同类型的对象:func newobject(id string) interface{} {switch id {case "truck":return truck{
如何限制特定类型的接口{}
2024-02-06

如何从http响应中提取特定标头

一分耕耘,一分收获!既然打开了这篇文章《如何从http响应中提取特定标头》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!问题
如何从http响应中提取特定标头
2024-04-05

python如何提取指定行和列的数据

在Python中,你可以使用numpy库来提取指定行和列的数据。假设你有一个2维数组data,你想要提取第2行和第3列的数据,可以使用以下代码:```pythonimport numpy as npdata = np.array([[1,
2023-08-23

如何通过 MySQL DESCRIBE 语句获取表中特定列的信息?

众所周知,DESCRIBE 语句将提供整个表的信息/结构。借助 DESCRIBE 语句以及表名和列名,我们可以获得有关该列的信息。语法DESCRIBE table_name col_name;示例1mysql> Describe emplo
2023-10-22

css中如何定义盒的类型

这篇文章主要介绍了css中如何定义盒的类型,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。css中使用display属性来定义盒的类型。display属性规定元素应该生成的框的
2023-06-06

如何用python提取txt文件中的特定信息并写入Excel

如何用python提取txt文件中的特定信息并写入Excel,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。问题描述:我有一个这样的数据集叫test_result_test.
2023-06-21

如何解决MySQL报错:列中的未知列类型

当MySQL报错“列中的未知列类型”时,可能是由于以下原因导致的:1. 列名拼写错误:检查查询语句中的列名是否正确拼写,包括大小写、空格等。2. 列名与表名冲突:确保查询语句中的列名与表名不会发生冲突。可以通过使用表别名来消除冲突。3. 数
2023-10-10

Python中如何获取类属性的列表

前言 最近工作中遇到个需求是要得到一个类的静态属性,也就是说有个类 Type ,我要动态获取 Type.FTE 这个属性的值。 最简单的方案有两个:getattr(Type, 'FTE') Type.__dict__['FTE']那么,如果
2022-06-04

C++ 函数异常处理中如何捕获特定类型的异常?

c++++ 中捕获特定类型异常的方法:使用 try-catch 块。在 catch 子句中指定要捕获的异常类型,如 catch (const std::runtime_error& e)。实战案例中,read_file() 函数通过抛出 s
C++ 函数异常处理中如何捕获特定类型的异常?
2024-04-15

mysql如何修改表中列的数据类型

要修改表中列的数据类型,可以使用 ALTER TABLE 语句来实现。以下是修改列数据类型的示例:ALTER TABLE 表名 MODIFY 列名 新数据类型;例如,如果要将表中的列 age 的数据类型从 INT 修改为 VARCHAR,
mysql如何修改表中列的数据类型
2024-04-22

如何在 Golang 中获取函数的类型?

在 golang 中,我们可以使用 reflect.typeof() 函数获取函数类型:获取函数类型:fntype := reflect.typeof(add)打印函数类型:fmt.println("函数类型:", fntype)获取函数名
如何在 Golang 中获取函数的类型?
2024-04-20

如何定义C++中的C++数据类型

这篇文章给大家介绍如何定义C++中的C++数据类型,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。着重介绍C++数据类型,C++中的C++数据类型定义编译器在内存中存放信息的方式,在不同的开发环境中,可以向变量赋予任何数
2023-06-17

vbs中如何使用adox实现提取数据库表名和列名的类

这篇文章主要介绍了vbs中如何使用adox实现提取数据库表名和列名的类,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。