首页 > 编程问答 >如何迭代 DataFrame 的行?

如何迭代 DataFrame 的行?

时间:2024-07-24 14:33:15浏览次数:5  
标签:python pandas dataframe iterator

我有这段代码:

df = pd.DataFrame(data, columns = ['Name','New_addy','PHONE1','PHONE2','EMAIL'])

def QuestioningMech(df):
    for x in df:
        print(df[x])

所以我试图迭代 DataFrame,但此代码迭代列。我该如何迭代行?


有几种方法可以迭代 Pandas DataFrame 的行:

1. 使用 iterrows()

iterrows() 方法将 DataFrame 作为 (index, Series) 对进行迭代。这是迭代行最常用的方法,因为它可以访问索引和每一行的值。

```python import pandas as pd

df = pd.DataFrame(data, columns=['Name', 'New_addy', 'PHONE1', 'PHONE2', 'EMAIL'])

def QuestioningMech(df): for index, row in df.iterrows(): print(f"Row {index + 1}:") # 打印行号 print(row['Name'], row['PHONE1']) # 访问特定列

QuestioningMech(df) ```

2. 使用 itertuples()

itertuples() 方法将 DataFrame 作为命名元组进行迭代。这比 iterrows() 更快,但不能访问索引,并且需要使用属性名访问列值。

```python import pandas as pd

df = pd.DataFrame(data, columns=['Name', 'New_addy', 'PHONE1', 'PHONE2', 'EMAIL'])

def QuestioningMech(df): for row in df.itertuples(): print(row.Name, row.PHONE1) # 使用属性名访问列

QuestioningMech(df) ```

3. 将 DataFrame 转换为列表:

可以使用 values 属性将 DataFrame 转换为 NumPy 数组,然后使用列表推导式迭代每一行。

```python import pandas as pd

df = pd.DataFrame(data, columns=['Name', 'New_addy', 'PHONE1', 'PHONE2', 'EMAIL'])

def QuestioningMech(df): for row in df.values: print(row[0], row[2]) # 使用索引访问列

QuestioningMech(df) ```

哪种方法最好?

  • 如果你需要访问索引和每一行的值, iterrows() 是最好的选择。
  • 如果你需要快速迭代行并且不需要索引, itertuples() 是一个不错的选择。
  • 如果你想将 DataFrame 转换为其他数据结构,例如列表,则将 DataFrame 转换为列表是一个不错的选择。

重要提示: 迭代大型 DataFrame 可能会很慢。 如果需要对 DataFrame 执行复杂的操作,请考虑使用 Pandas 的内置函数和矢量化操作,而不是迭代行。 这些函数通常比循环快得多,并且更易于阅读和理解。

标签:python,pandas,dataframe,iterator
From: 72469112

相关文章

  • python带界面实现word文档比对功能
    python实现word文档比对的功能较简单,笔者这里将其界面话,可以指定输入比对的文档,相似度,最小相似参数等。输出的结果以word的形式保存,重复部分会标出,基本实现了商业软件的功能。先看界面这里不废话了,直接给出全部源码,觉得好的点个赞。程序打包的话,自己百度。fromtkinterimp......
  • 具有固定字典键的 Python 函数返回类型提示
    我有一个函数返回一个始终具有相同键的字典(通过网络发送并使用json进行“字符串化”)。基本上我的函数看起来像这样:defgetTemps(self)->dict:"""getroomandcputemperaturein°Caswellashumidityin%"""#sendtemperaturerequesttoserve......
  • 在类型提示中使用 Type[class_name] 而不是仅使用 class_name 时,python 未解析的属性
    我想输入提示继承结构,但我不知道如何正确执行。这个想法是函数c可以采用A的任何子类。一些子类具有其他子类没有的属性,并且这些属性不是在父类中定义,而是在子类中定义。函数c检查子类,如果它是正确的,则使用该类的特定属性。在此设置中,PyCharm抱怨该参数不在父类中。from......
  • python的包管理
    获取现有项目有那些依赖安装pipreqspipinstallpipreqs在项目根目录执行pipreqs.--encoding=utf8--force--pypi-server=http://mirrors.aliyun.com/pypi/simple/根据生成文件安装依赖pipinstall-rrequriements.txtpipreqs命令选项Options:--use-local......
  • 如何在 python selenium 中禁用广告隐私设置?
    我对上面有一些问题。当然,当我尝试绕过cloudflare验证码时,我的策略已经破坏了任何cloudflare。但有一些问题。当我在pythonselenium中打开新选项卡时,会弹出广告隐私窗口。谁有解决这个问题的经验。谢谢您的帮助。一旦通过,就不会再发生了。我理解你想在......
  • [附开题]flask框架的基于微信小程序的医院远程预约挂号系统设计与实现6ky98(python+源
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着医疗需求的日益增长和互联网技术的飞速发展,传统的医院挂号方式已难以满足患者高效、便捷的就医需求。患者往往需要长时间排队等待挂号......
  • [附开题]flask框架的基于用户行为分析的商品推荐系统APP1qut6APP(python+源码)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景在移动互联网时代,电子商务平台的竞争日益激烈,如何精准地推荐商品给用户,提升用户体验与购买转化率,成为电商企业关注的焦点。传统的推荐算法......
  • [附开题]flask框架的教务管理系统q6190(源码+论文+python)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展和教育改革的不断深入,教务管理工作日益复杂且重要。传统的手工管理方式已难以满足当前高校教务管理的需求,特别是在......
  • python闭包和装饰器
    一、闭包1.闭包的三要素1.外部函数嵌套内部函数2.内部函数可以调用外部函数的局部变量3.外部函数返回内部函数2.示例代码 #外部函数deffunc1():print("func1")#内部函数deffunc2():print("func2")#外部函数返回内部函数re......
  • python Subprocess 模块
    Subprocess介绍subprocess模块是Python标准库中的一个模块,用于管理子进程(子程序)。通过subprocess模块,可以在Python脚本中启动新的进程、连接到它们的输入/输出流以及获取它们的返回值。Subprocess主要功能1.执行外部命令:subprocess允许你在Python脚本中执行系统命......