百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

python数据分析:对pandas的Series和DataFrame数据做循环遍历

liuian 2025-04-09 17:51 51 浏览

知识点

对Series和DataFrame对象及values属性做循环遍历;

对DataFrame对象使用iterrows函数和itertuples函数按行做循环遍历,使用items函数按列做循环遍历 。

安装和使用pandas

使用前提前安装pandas库:

pip install pandas -i https://mirrors.aliyun.com/pypi/simple/

使用时直接导入即可

import pandas as pd

Series数据循环遍历

Series对象是一个一维数组,类似于list列表

1)对Series对象直接遍历

# 从列表创建 Series
data = [1, 2, 3, 4, 5]
s = pd.Series(data)
for i in s:
   pritn(i)

结果:

1
2
3
4
5

2)对Series的values属性(返回 Series中的数据值)遍历

举例:定义一个series接口数据并指定索引和名称

data = [[1, 2, 3], [4, 5,6]]
s = pd.Series(data, name='一维数组',index=['a', 'b'])
for i in s.values:
   pritn(i)

结果:

[1, 2, 3]
[4, 5, 6]

2. DataFrames数据循环遍历

DataFrame 是一个二维的表格数据结构,具有标记的轴(行和列)。其中每一列相当于一个Series。

我们先定义一个DataFrame对象

import pandas as pd
# 从字典创建 DataFrame,字典的键是列名
data_dict = {
'name': ['lilei', 'lili', 'wanglei'],
'age': [25, 30, 35],
'city': ['shanghai', 'shenzhen', 'nanjing']
}
df = pd.DataFrame(data_dict)

1)对DataFrame的values属性做循环遍历(按行迭代)

for i in df.values:
   print(i,type(i))

结果:每行返回的是一个numpy数组

['lilei' 25 'shanghai'] 
['lili' 30 'shenzhen'] 
['wanglei' 35 'nanjing'] 

我们可以继续对每个numpy数组做循环遍历,获取每个元素的值

for i in df.values:
   for j in i:
      print(j)

结果:

2)iterrows函数:对DataFrame对象做循环遍历(按行迭代)

iterrows函数是一个生成器,每次循环时返回一个元组,元组的第一个元素是索引,第二个元素是每行对应的Series对象

举例:对iterrows函数做循环遍历

for i in df.iterrows():
   print(i)

结果:显示每一行为一个元组

我们继续对每个元组的第2个元素做循环遍历

上面的for循环语句变成如下:

for i in df.iterrows():
   for j in i[1]:
      print(j)

结果显示遍历得到的是每行中的值。

3)itertuples函数:对DataFrame对象做循环遍历(按行迭代)

itertuples函数返回namedtyple元组,参数index默认为True,则元组的第一个元素是索引,第二个元素是每行对应的namedtuple对象 ; 传值为False则不增加索引值,直接返回namedtuple对象

举例:对itertuples函数做循环遍历,参数index=False

for i in df.itertuples(index=False):
   print(i,type(i))
   for j in i:
      print(j)

结果显示遍历得到的是每行中的值。

4)items函数:对DataFrame对象做循环遍历(按列迭代)

items函数是一个生成器,每次循环返回的元组中第一个元素是列名,第二个元素是每列对应的Series对象。

举例:对items函数做循环遍历,并打印第2个元素的type

for i in df.items():
   print(i,type(i[1]))

结果:每个元组第1个元素为列名,第2个元素为每列的Series对象

我们继续对第2个元素做循环,得到每列的值:

for i in df.items():
   for j in i[1]:
      print(j)

结果:

5)直接对DataFrame对象做循环遍历(按列迭代)

举例:对DataFrame对象循环遍历,可以得到每个列名

for i in df:
   print(i)

结果:

name
age
city

我们继续通过列名得到每一列的Series对象,并做循环


for i in df:
   for j in df[i]:
      print(j)

结果:

或者我们直接对某一列做循环处理,比如对name这一列

for i in df['name']:
   print(i)

结果:

lilei
lili
wanglei

共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳。

----感谢读者的阅读和学习,谢谢大家。

相关推荐

十大最好用的浏览器(市面上最好用的浏览器)

1、谷歌chrone  谷歌美国Google公司开发的一款浏览器,谷歌浏览器的特点就是界面简洁,速度快不卡顿,内容全面,你想要找到内容上面都有,就是在安装插件的方面会比较麻烦,不过看在它那么好用的份...

ipad充不上电了怎么办(ipad充不上电怎么办但显示在充电)

 原因和解决办法: 1、ipad充不进去电很可能是充电线的原因,假如大家在给ipad充电的时候以前经常有过接触不良的情况,那么,你就需要考虑更换充电线了。  2、第二,就是接口问题了,或者说是充电...

怎样取消开机启动项目(如何取消开机启动程序)

在Windows操作系统中,有一些程序或服务可能会在计算机启动时自动运行,这些程序或服务也被称为开机启动项。如果您希望在启动Windows时减少计算机运行的程序或服务数量,您可以关闭一些开机启...

纯净版win7完整版ghost下载(纯净版的win7)

1、去微软官方网站下载。2、去系统之家下载,我自己的win10就是从哪里下载安装的,你可以试试哈。ghost镜像的使用一、备份主分区--C盘:假设你的操作系统安装在主分区--C盘,当系统重装不久,或...

联想台式机重装系统按哪个键

联想电脑第一部,如果像进入装系统的界面,必须按f8,if8进入装系统的界面,这时候把下载好的U盘系统安装包直接插在主机上,直接就可以安装系统了,大概20分钟后就可以安装系统,安装系统就可以正常使用了...

360无法卸载怎么办(360卸载不了最简单三个步骤)

开启了自我保护,关闭即可。解决方法如下:准备材料:360安全卫士、电脑1、在电脑上打开安全卫士,进去之后,点击右上方的列表图标,选择设置,2、进去安全卫士设置界面之后,点击安全防护中心,3、进去安全防...

戴尔笔记本电脑没有声音怎么解决

右击“我的电脑”----“属性”---“硬件”----“设备管理器”,打开“声音、视频和游戏控制器”有无问题,即看前面有没有出现黄色的小图标,如有,重新安装这个设备的驱动程序进行解决。加强麦克风:右...

如何给无线路由器设置密码(如何给无线路由器设置密码教程)

1、使用路由器的管理界面,找到密码设置选项,输入想要设置的新密码。   2、再次输入新密码,以便确认输入的密码正确无误。   3、保...

windows7旗舰版激活序列号(win7旗舰 激活码)

一、Windows7旗舰版激活密钥零售版:Windows7UltimateRetail永久序列号【尝试联网激活,如果不能激活,可电话激活】[Key]:RHTBY-VWY6D-QJRJ9-JGQ...

联想电脑如何重置系统(联想电脑 重置系统)

联想进入bios界面重置系统方法:1、将电脑关机,按下一键恢复按钮(需确保笔记本屏盖在打开状态),不同的联想笔记本机型按钮位置不同,操作也不一样1)如果是此按钮,按住5秒钟等待出现还原界面2)针孔式按...

电脑加密文件夹怎么弄(电脑加密文件夹怎么弄出来)

要在电脑中加密文件夹,可以使用加密软件或操作系统提供的加密功能。使用加密软件,你可以选择文件夹并设置密码来保护其内容。这样,只有输入正确密码的人才能访问文件夹中的文件。另外,某些操作系统也提供了加密文...

win11打游戏现在稳定吗(win11玩游戏流畅吗)

win11适合打游戏的。主要原因如下:1、win11的升级并不会丢失原本系统中的文件和软件,因此用户可以在升级后直接玩原本的游戏。2、win11虽然是一款新系统,但是在游戏性能的表现上已经有着非常好的...

无法连接到共享打印机(无法连接到共享打印机是啥情况)

这个有多种原因,主要是要启动来宾guest帐户,装好驱动,设置同一工作组,在同一局域网条件下,重新添加打印机就可以了。1、依次展开“计算机管理(本地)—系统工具—本地用户和组—用户”,找到G...

注册qq号免费立即申请不用手机号

1、先在网页上搜索安装谷歌浏览器2、安装完成后,不要在电脑上登录任何一个QQ,打开QQ登录的界面,点击注册账号。3、在注册账号的页面,填上相应要求的信息,手机号码的部分先不要填。4、点击谷歌浏览器右上...

office2016破解版安装教程(office2016下载破解版)

microsoftoffice2016激活与破解的区别是版本不同。①尽量使用官方的原版程序、原版软件,避免使用来路不明的"XX"版。②若程序对非正版授权用户有功能或使用期限制,但仍能满...