
在数据清洗和预处理阶段,我们经常需要对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”,这与我们的预期(保持不变)不符。这种无差别的处理方式显然无法满足条件性操作的需求。
为了实现精确的条件性字符串处理,我们可以结合Python的条件语句和Pandas的apply方法。apply方法允许我们对DataFrame的每一行或每一列应用一个自定义函数,从而实现复杂的逻辑。
首先,我们定义一个辅助函数来处理单个地址字符串:
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)代码解析:
使用这种方法,输出结果将完全符合预期:
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)代码解析:
本教程详细介绍了如何在Pandas DataFrame中实现有条件的字符串列处理。我们首先指出了无差别操作可能带来的问题,接着展示了如何利用自定义函数结合apply方法实现精确的条件逻辑,并通过.strip()确保数据清洁。最后,我们还探讨了使用np.where和矢量化字符串方法来提升处理效率的替代方案。掌握这些技巧,将使您在处理实际数据清洗任务时更加得心应手。
以上就是Python Pandas:条件性拆分DataFrame字符串列并重构特定子串的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号