0

0

Python Pandas:条件性拆分DataFrame字符串列并重构特定子串

碧海醫心

碧海醫心

发布时间:2025-09-26 15:58:11

|

570人浏览过

|

来源于php中文网

原创

Python Pandas:条件性拆分DataFrame字符串列并重构特定子串

本教程深入探讨如何在Pandas DataFrame中根据特定词语是否存在,有条件地拆分字符串列,并精准地重新拼接子串。我们将通过一个地址列的实际案例,展示如何使用自定义函数结合apply方法实现精确的字符串处理,避免对不符合条件的行进行不必要的修改,并提供更高效的矢量化替代方案,以应对不同规模的数据处理需求。

引言:DataFrame字符串处理的挑战

数据清洗和预处理阶段,我们经常需要对pandas dataframe中的字符串列进行操作。一个常见的场景是,只有当字符串中包含某个特定关键词时,才对其进行拆分、截取或修改。例如,我们有一个包含地址信息的address列:

address
xxx City yyy road 17 number 8 floor west bank
ttt City iii road 1 number
ggg City kkk road 25 number 1 floor apple store

我们的目标是:如果地址包含“floor”这个词,我们就需要截取“floor”之前的所有内容,然后重新拼接上“ floor”。如果地址不包含“floor”,则保持原始地址不变。

期望的输出结果如下:

xxx City yyy road 17 number 8 floor
ttt City iii road 1 number
ggg City kkk road 25 number 1 floor

常见误区:无差别处理的局限性

初学者可能会尝试一种直接的字符串操作方法,例如:

import pandas as pd

data = {'address': [
    'xxx City yyy road 17 number 8 floor west bank',
    'ttt City iii road 1 number',
    'ggg City kkk road 25 number 1 floor apple store'
]}
df = pd.DataFrame(data)

df['address_modified'] = df['address'].str.split('floor').str[0] + 'floor'
print(df)

这段代码的输出结果会是:

立即学习Python免费学习笔记(深入)”;

                                         address             address_modified
0  xxx City yyy road 17 number 8 floor west bank  xxx City yyy road 17 number 8 floor
1                     ttt City iii road 1 number         ttt City iii road 1 number floor
2  ggg City kkk road 25 number 1 floor apple store  ggg City kkk road 25 number 1 floor

可以看到,对于第二行“ttt City iii road 1 number”,由于它不包含“floor”,str.split('floor')会返回一个只包含原始字符串的列表,即['ttt City iii road 1 number']。str[0]依然是原始字符串,然后被强制拼接了“floor”,这与我们的预期(保持不变)不符。这种无差别的处理方式显然无法满足条件性操作的需求。

精确控制:使用自定义函数与apply

为了实现精确的条件性字符串处理,我们可以结合Python的条件语句和Pandas的apply方法。apply方法允许我们对DataFrame的每一行或每一列应用一个自定义函数,从而实现复杂的逻辑。

首先,我们定义一个辅助函数来处理单个地址字符串:

Giiso写作机器人
Giiso写作机器人

Giiso写作机器人,让写作更简单

下载
def process_address(address):
    """
    根据地址是否包含'floor'进行条件性处理。
    如果包含,则截取'floor'之前的部分并重新添加' floor';
    否则,返回原始地址。
    """
    if 'floor' in address:
        # 拆分字符串,获取'floor'之前的部分
        # .strip() 用于去除可能存在的首尾空白字符
        return address.split('floor')[0].strip() + ' floor'
    else:
        # 如果不包含'floor',则返回原始地址
        return address

# 将自定义函数应用到DataFrame的'address'列
df['processed_address'] = df['address'].apply(process_address)
print(df)

代码解析:

  1. process_address(address)函数:
    • 它接收一个字符串参数address。
    • if 'floor' in address::首先检查address字符串中是否包含子字符串“floor”。
    • 如果条件为真(包含“floor”):
      • address.split('floor')[0]:将字符串按“floor”分割,并取第一个元素(即“floor”之前的部分)。
      • .strip():这是一个非常重要的步骤,用于去除split()操作后可能残留在字符串末尾的空格。例如,“...number 8 ”在split('floor')后可能会留下尾部空格,strip()可以清除这些多余的空格。
      • + ' floor':最后,将处理后的字符串重新拼接上“ floor”。注意这里加了一个空格,以保持格式一致性。
    • 如果条件为假(不包含“floor”):
      • return address:直接返回原始的address字符串,不做任何修改。
  2. df['processed_address'] = df['address'].apply(process_address):
    • 这行代码将我们定义的process_address函数应用到df的'address'列的每一个元素上。
    • apply方法会逐行调用process_address函数,并将每行的结果赋值给新创建的'processed_address'列。

使用这种方法,输出结果将完全符合预期:

                                         address          processed_address
0  xxx City yyy road 17 number 8 floor west bank  xxx City yyy road 17 number 8 floor
1                     ttt City iii road 1 number           ttt City iii road 1 number
2  ggg City kkk road 25 number 1 floor apple store  ggg City kkk road 25 number 1 floor

性能优化:矢量化操作的替代方案

虽然apply方法非常灵活且易于理解,但对于非常大的数据集,它可能会比Pandas的内置矢量化字符串方法(str访问器)效率低。在某些情况下,我们可以通过结合str.contains、np.where或mask来实现更高效的矢量化操作。

以下是使用numpy.where实现的矢量化方法:

import numpy as np

# 假设df已存在,且包含'address'列
# 创建一个布尔条件 Series,指示哪些行包含'floor'
# na=False 处理可能存在的NaN值,将其视为不包含'floor'
condition = df['address'].str.contains('floor', na=False)

# 使用np.where进行条件性赋值
# 如果条件为真,执行第一个操作;否则,执行第二个操作
df['processed_address_vec'] = np.where(
    condition,
    df['address'].str.split('floor').str[0].str.strip() + ' floor', # 如果包含'floor'
    df['address']                                                 # 如果不包含'floor'
)
print(df)

代码解析:

  1. condition = df['address'].str.contains('floor', na=False):
    • str.contains('floor')会返回一个布尔型Series,指示address列中的每个字符串是否包含“floor”。
    • na=False参数确保如果address列中有NaN值,它们会被视为不包含“floor”,避免产生错误。
  2. np.where(condition, value_if_true, value_if_false):
    • np.where是一个Numpy函数,它根据一个布尔条件数组来选择两个值数组中的元素。
    • 当condition为True时,它会从第二个参数(df['address'].str.split('floor').str[0].str.strip() + ' floor')中选择对应的值。
    • 当condition为False时,它会从第三个参数(df['address'])中选择对应的值。
    • 这里的str.split().str[0].str.strip()操作是针对整个Series进行的矢量化操作,通常比apply更快。

注意事项与最佳实践

  1. 空白字符处理 (.strip()): 始终考虑在拆分或拼接字符串后使用.strip()来清理多余的空白字符,以确保数据的一致性和准确性。
  2. 大小写敏感性: in操作符和str.contains()默认是大小写敏感的。如果需要进行不区分大小写的匹配,可以先将字符串转换为统一大小写(例如,address.lower()或df['address'].str.lower())再进行判断。
  3. 空值 (NaN) 处理: 在使用str访问器时,如果列中存在NaN值,直接进行字符串操作可能会导致错误。str.contains(..., na=False)是一个很好的实践,它会将NaN值处理为False,避免程序中断。
  4. 创建新列: 建议将处理结果存储在一个新列中,例如processed_address或processed_address_vec,而不是直接覆盖原始列。这有助于保留原始数据,方便后续验证和回溯。
  5. 选择方法:
    • 对于简单的条件逻辑和较小的数据集,apply方法结合自定义函数非常直观和易于实现。
    • 对于复杂的条件和大型数据集,np.where或mask等矢量化方法通常能提供更好的性能。

总结

本教程详细介绍了如何在Pandas DataFrame中实现有条件的字符串列处理。我们首先指出了无差别操作可能带来的问题,接着展示了如何利用自定义函数结合apply方法实现精确的条件逻辑,并通过.strip()确保数据清洁。最后,我们还探讨了使用np.where和矢量化字符串方法来提升处理效率的替代方案。掌握这些技巧,将使您在处理实际数据清洗任务时更加得心应手。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

659

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1325

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 10.9万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号