这里我们创建一个DataFrame
命名为df
:
import numpy as np
import pandas as pd
d = np.array([[81, 28, 24, 25, 96],
[ 8, 35, 56, 98, 39],
[13, 39, 55, 36, 3],
[70, 54, 69, 48, 12],
[63, 80, 97, 25, 70]])
df = pd.DataFrame(data = d,
columns=list('abcde'))
df
a | b | c | d | e | |
---|---|---|---|---|---|
0 | 81 | 28 | 24 | 25 | 96 |
1 | 8 | 35 | 56 | 98 | 39 |
2 | 13 | 39 | 55 | 36 | 3 |
3 | 70 | 54 | 69 | 48 | 12 |
4 | 63 | 80 | 97 | 25 | 70 |
查看前n行
df.head(2)
a | b | c | d | e | |
---|---|---|---|---|---|
0 | 81 | 28 | 24 | 25 | 96 |
1 | 8 | 35 | 56 | 98 | 39 |
查看后n行
df.tail(2)
a | b | c | d | e | |
---|---|---|---|---|---|
3 | 70 | 54 | 69 | 48 | 12 |
4 | 63 | 80 | 97 | 25 | 70 |
查看随机N行
df.sample(2)
a | b | c | d | e | |
---|---|---|---|---|---|
1 | 8 | 35 | 56 | 98 | 39 |
3 | 70 | 54 | 69 | 48 | 12 |
单列选取,我们有3种方式可以实现
第一种,直接在[]
里面写上要筛选的列名
df['a']
0 81
1 8
2 13
3 70
4 63
Name: a, dtype: int64
第二种,在.iloc[]
里的,
前面写上要筛选的行索引,在,
后面写上要筛选的列索引。其中:
代表所有,0:3
代表从索引0到2
df.iloc[0:3,0]
0 81
1 8
2 13
Name: a, dtype: int64
第三种,直接.
后面写上列名
df.a
0 81
1 8
2 13
3 70
4 63
Name: a, dtype: int64
同样的,选择多列常见的也有3种方式:
第一种,直接在[]
里面写上要筛选的列名组成的列表['a','c','d']
df[['a','c','d']]
a | c | d | |
---|---|---|---|
0 | 81 | 24 | 25 |
1 | 8 | 56 | 98 |
2 | 13 | 55 | 36 |
3 | 70 | 69 | 48 |
4 | 63 | 97 | 25 |
第二种,在.iloc[]
里面行索引位置写:
选取所有行,列索引位置写上要筛选的列索引组成的列表[0,2,3]
df.iloc[:,[0,2,3]]
a | c | d | |
---|---|---|---|
0 | 81 | 24 | 25 |
1 | 8 | 56 | 98 |
2 | 13 | 55 | 36 |
3 | 70 | 69 | 48 |
4 | 63 | 97 | 25 |
第三种,在.loc[]
里面的行索引位置写:
来选取所有行,在列索引位置写上要筛选的列索引组成的列表['a','c','d']
df.loc[:,['a','c','d']]
a | c | d | |
---|---|---|---|
0 | 81 | 24 | 25 |
1 | 8 | 56 | 98 |
2 | 13 | 55 | 36 |
3 | 70 | 69 | 48 |
4 | 63 | 97 | 25 |
直接选取第一行
df[0:1]
a | b | c | d | e | |
---|---|---|---|---|---|
0 | 81 | 28 | 24 | 25 | 96 |
用loc
选取第一行
df.loc[0:0]
a | b | c | d | e | |
---|---|---|---|---|---|
0 | 81 | 28 | 24 | 25 | 96 |
选取任意多行
df.iloc[[1,3],]
a | b | c | d | e | |
---|---|---|---|---|---|
1 | 8 | 35 | 56 | 98 | 39 |
3 | 70 | 54 | 69 | 48 | 12 |
选取连续多行
df.iloc[1:4,:]
a | b | c | d | e | |
---|---|---|---|---|---|
1 | 8 | 35 | 56 | 98 | 39 |
2 | 13 | 39 | 55 | 36 | 3 |
3 | 70 | 54 | 69 | 48 | 12 |
指定行列值
df.iat[2,2] # 根据行列索引
55
df.at[2,'c'] # 根据行列名称
55
指定行列区域
df.iloc[[2,3],[1,4]]
b | e | |
---|---|---|
2 | 39 | 3 |
3 | 54 | 12 |
以上是关于如何查看一个DataFrame里的数据,包括用[]
、iloc
、iat
等方式选取数据,接下来我们来看如何用条件表达式来筛选数据:
这里分享一个你一定用得到的小程序——CDA数据分析师考试小程序。 它是专为CDA数据分析认证考试报考打造的一款小程序。可以帮你快速报名考试、查成绩、查证书、查积分,通过该小程序,考生可以享受更便捷的服务。 扫码加入CDA小程序,与圈内考生一同学习、交流、进步!
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
持证人简介:贺渲雯 ,CDA 数据分析师一级持证人,互联网行业数据分析师 今天我将为大家带来一个关于用户私域用户质量数据分析 ...
2025-04-18一、CDA持证人介绍 在数字化浪潮席卷商业领域的当下,数据分析已成为企业发展的关键驱动力。为助力大家深入了解数据分析在电商行 ...
2025-04-17CDA持证人简介:居瑜 ,CDA一级持证人,国企财务经理,13年财务管理运营经验,在数据分析实践方面积累了丰富的行业经验。 一、 ...
2025-04-16持证人简介: CDA持证人刘凌峰,CDA L1持证人,微软认证讲师(MCT)金山办公最有价值专家(KVP),工信部高级项目管理师,拥有 ...
2025-04-15持证人简介:CDA持证人黄葛英,ICF国际教练联盟认证教练,前字节跳动销售主管,拥有丰富的行业经验。在实际生活中,我们可能会 ...
2025-04-14在 Python 编程学习与实践中,Anaconda 是一款极为重要的工具。它作为一个开源的 Python 发行版本,集成了众多常用的科学计算库 ...
2025-04-14随着大数据时代的深入发展,数据运营成为企业不可或缺的岗位之一。这个职位的核心是通过收集、整理和分析数据,帮助企业做出科 ...
2025-04-11持证人简介:CDA持证人黄葛英,ICF国际教练联盟认证教练,前字节跳动销售主管,拥有丰富的行业经验。 本次分享我将以教培行业为 ...
2025-04-11近日《2025中国城市长租市场发展蓝皮书》(下称《蓝皮书》)正式发布。《蓝皮书》指出,当前我国城市住房正经历从“增量扩张”向 ...
2025-04-10在数字化时代的浪潮中,数据已经成为企业决策和运营的核心。每一位客户,每一次交易,都承载着丰富的信息和价值。 如何在海量客 ...
2025-04-09数据是数字化的基础。随着工业4.0的推进,企业生产运作过程中的在线数据变得更加丰富;而互联网、新零售等C端应用的丰富多彩,产 ...
2025-04-094月7日,美国关税政策对全球金融市场的冲击仍在肆虐,周一亚市早盘,美股股指、原油期货、加密货币、贵金属等资产齐齐重挫,市场 ...
2025-04-08背景 3月26日,科技圈迎来一则重磅消息,苹果公司宣布向浙江大学捐赠 3000 万元人民币,用于支持编程教育。 这一举措并非偶然, ...
2025-04-07在当今数据驱动的时代,数据分析能力备受青睐,数据分析能力频繁出现在岗位需求的描述中,不分岗位的任职要求中,会特意标出“熟 ...
2025-04-03在当今数字化时代,数据分析师的重要性与日俱增。但许多人在踏上这条职业道路时,往往充满疑惑: 如何成为一名数据分析师?成为 ...
2025-04-02最近我发现一个绝招,用DeepSeek AI处理Excel数据简直太爽了!处理速度嘎嘎快! 平常一整天的表格处理工作,现在只要三步就能搞 ...
2025-04-01你是否被统计学复杂的理论和晦涩的公式劝退过?别担心,“山有木兮:统计学极简入门(Python)” 将为你一一化解这些难题。课程 ...
2025-03-31在电商、零售、甚至内容付费业务中,你真的了解你的客户吗? 有些客户下了一两次单就消失了,有些人每个月都回购,有些人曾经是 ...
2025-03-31在数字化浪潮中,数据驱动决策已成为企业发展的核心竞争力,数据分析人才的需求持续飙升。世界经济论坛发布的《未来就业报告》, ...
2025-03-28你有没有遇到过这样的情况?流量进来了,转化率却不高,辛辛苦苦拉来的用户,最后大部分都悄无声息地离开了,这时候漏斗分析就非 ...
2025-03-27