7.3 字符串操作

pandas加强了Python的字符串和文本处理功能,使得能够对整组数据应用字符串表达式和正则表达式,且能够处理烦人的缺失数据。

7.3.1 字符串对象方法

对于许多字符串处理和脚本应用,内置的字符串方法能够满足要求。

1)用split将以逗号分隔的字符串拆分成数段

2)split常与strip一起使用,用于去除空白符(包括换行符)

3)利用加法,可将这些字符串以其他符号(如,双冒号)分隔的形式连接起来

  Ps:该方式不实用,可用向字符串"::"的join方法传入一个列表或元组:

  

4)子串定位。检测子串的最佳方式是利用Python的in关键字,还可使用index和find

  Ps:注意find和index区别,如果找不到字符串,index将会引发一个异常(而不是像find一样,返回-1)

5)count可返回指定子串的出现次数

表7-3 Python内置的字符串方法(这些运算大部分都能使用正则表达式实现)

7.3.2 正则表达式

正则表达式提供了一种灵活的在文本中搜索或匹配(通常比前者复杂)字符串模式的方式。

正则表达式,称作regex。是根据正则表达式语言编写的字符串。Python内置的re模块负责对字符串应用正则表达式。

(正则表达式的编写技巧可用自成一章,更多相关内容网上找教程学习)

re模块的函数分为三大类:模式匹配、替换以及拆分。regex描述了需要在文本中定位的一个模式。

1)描述一个或多个空白符的regex是\s+

例子,拆分一个字符串,分隔符为数量不定的一组空白符(制表符、空格、换行符等)

  调用re.split('\s+',text)时,正则表达式会先被编译,然后再在text上调用其split方法。可用re.compile自己编译reges以得到一个可重用的regex对象:

  

  如果只希望得到匹配regex的所有模式,则可使用findall方法:

  

  Ps:如果想避免正则表达式中不需要的转义(\),则可使用原始字符串字面量,如 r'C:\x'

  如果打算对许多字符串应用同一条正则表达式,强烈建议通过re.compile创建regex对象。如此可节省大量的CPU时间。

2)match和search跟findall功能类似

findall返回的是字符串中所有匹配项,而search则只返回第一个匹配项。match更加严格,它只匹配字符串的首部。

例子:

对text使用findall将得到一组电子邮件:

search返回的是文本中第一个电子邮件地址(以特殊的匹配项对象形式返回)。对于上面的regex,匹配项对象只能告诉我们模式在原字符串中的起始位置和结束位置:

regex.match则将返回None,因为它只匹配出现在字符串开头的模式:

3)sub方法。可将匹配到的模式替换为指定字符串,并返回所得到的新字符串:

4)如不仅想找出电子邮件地址,还想将各个地址分成3个部分:用户名、域名以及域后缀。实现此功能,只需将待分段的模式的各部分用圆括号包起来:

  Ps:对于带有分组功能的模式,findall会返回一个如上所示的元组列表

由这种修改过的正则表达式所产生的匹配项对象,可通过其groups方法返回一个由模式各段组成的元组:

5)sub还能通过诸如\1、\2之类的特殊符号访问各匹配项中的分组。符合\1对应第一个匹配的组,\2对应第二个匹配的组,以此类推:

表7-4 正则表达式方法

7.3.3 pandas的矢量化字符串函数

清理待分析的散乱数据时,常需要做一些字符串规整化工作。更为复杂的情况是,含有字符串的列有时还含有缺失数据:

1)通过data.map,所有字符串和正则表达式方法都能被应用于(传入lambda表达式或其他函数)各个值,但是如果存在NA(null)就会报错。为解决该问题,Series有一些能够跳过NA值的面向数组方法,进行字符串操作。通过Series的str属性即可访问这些方法。

如,通过str.contains检查各个电子邮件地址是否含有"gamil":

  也可使用正则表达式,还可加上任意re选项(如,IGNORECASE):

  

2)实现矢量化的元素获取操作,有两个方法:要么使用str.get,要么在str属性上使用索引:

要访问嵌入列表中的元素,可传递索引到这两个函数中:

3)可利用这种方法对字符串进行截取:

表7-5 更多pandas字符串方法

7.4 总结

高效的数据准备,可以为数据分析留出更多时间。下一章,将学习pandas的聚合与分组。

利用Python进行数据分析 第7章 数据清洗和准备(2)的更多相关文章

  1. 利用Python进行数据分析 第7章 数据清洗和准备(1)

    学习时间:2019/10/25 周五晚上22点半开始. 学习目标:Page188-Page217,共30页,目标6天学完,每天5页,预期1029学完. 实际反馈:集中学习1.5小时,学习6页:集中学习 ...

  2. 利用Python进行数据分析 第4章 IPython的安装与使用简述

    本篇开始,结合前面所学的Python基础,开始进行实战学习.学习书目为<利用Python进行数据分析>韦斯-麦金尼 著. 之前跳过本书的前述基础部分(因为跟之前所学的<Python基 ...

  3. 利用Python进行数据分析 第6章 数据加载、存储与文件格式(2)

    6.2 二进制数据格式 实现数据的高效二进制格式存储最简单的办法之一,是使用Python内置的pickle序列化. pandas对象都有一个用于将数据以pickle格式保存到磁盘上的to_pickle ...

  4. 利用Python进行数据分析 第4章 NumPy基础-数组与向量化计算(3)

    4.2 通用函数:快速的元素级数组函数 通用函数(即ufunc)是一种对ndarray中的数据执行元素级运算的函数. 1)一元(unary)ufunc,如,sqrt和exp函数 2)二元(unary) ...

  5. 利用Python进行数据分析 第8章 数据规整:聚合、合并和重塑.md

    学习时间:2019/11/03 周日晚上23点半开始,计划1110学完 学习目标:Page218-249,共32页:目标6天学完(按每页20min.每天1小时/每天3页,需10天) 实际反馈:实际XX ...

  6. 利用Python进行数据分析 第5章 pandas入门(2)

    5.2 基本功能 (1)重新索引 - 方法reindex 方法reindex是pandas对象地一个重要方法,其作用是:创建一个新对象,它地数据符合新地索引. 如,对下面的Series数据按新索引进行 ...

  7. 利用Python进行数据分析 第5章 pandas入门(1)

    pandas库,含有使数据清洗和分析工作变得更快更简单的数据结构和操作工具.pandas是基于NumPy数组构建. pandas常结合数值计算工具NumPy和SciPy.分析库statsmodels和 ...

  8. 《利用python进行数据分析》读书笔记 --第一、二章 准备与例子

    http://www.cnblogs.com/batteryhp/p/4868348.html 第一章 准备工作 今天开始码这本书--<利用python进行数据分析>.R和python都得 ...

  9. 《利用Python进行数据分析·第2版》第四章 Numpy基础:数组和矢量计算

    <利用Python进行数据分析·第2版>第四章 Numpy基础:数组和矢量计算 numpy高效处理大数组的数据原因: numpy是在一个连续的内存块中存储数据,独立于其他python内置对 ...

随机推荐

  1. 使用IDEA运行CAS5.3服务器

    在上节中,我们运行CAS服务器是打成war包在tomcat中进行运行,这节介绍在IDEA中运行CAS服务器. 1.下载CAS 模板 Overlay Template,我这里使用 Apereo CAS ...

  2. Spring Boot|监控-Actuator

    Spring Boot 为我们提供了一个生产级特性-Actuator,包含很多实际有用的API,下面我们就一起来看看这些API. 一.Actuator 首先在程序中引入Actuator <!-- ...

  3. zabbix基于docker安装

    centos的版本 # cat /etc/redhat-release CentOS Linux release (Core) docker的安装 配置yum源 # vim /etc/yum.repo ...

  4. SQL查询练习题

    1.查询学生"百里守约"的基本信息 select * from students where name='百里守约' 2.查询学生百里守约"或"百里玄策&quo ...

  5. useReducer代替Redux小案例-2(八)

    通过上节课的学习,用useContext实现了Redux状态共享的能力,这节课看一下如何使用useReducer来实现业务逻辑的控制.需要注意的是这节课的内容是接着上节课的,需要你把上节课的代码部分完 ...

  6. Java里如何将一个字符串重复n次

    程序: import java.util.Collections; public class RepeatString { public static String getRepeatSpace(St ...

  7. 伪代码Pseudocode

    程序员之间交流,比划来比划去,与其用产品经理擅长的各种类图.时序图,还不如来一段伪代码来的直接! 伪代码 伪代码(Pseudocode)是一种算法描述语言.使用伪代码的目的是为了使被描述的算法可以容易 ...

  8. layui日历控件设置选择日期不能超过当前日期

    layui.use('laydate', function() { var laydate = layui.laydate; laydate.render({ elem : '#begin', max ...

  9. 内存检测工具valgrind的安装和简单使用

    1. 安装 .tar.bz2 cd valgrind- sudo ./configure sudo make sudo make install 2. 简单使用 #include <stdio. ...

  10. MySQL数据库查找多个字段值全部相同的记录

    数据库中用户表,数据从第三方系统导入,由于一些垃圾数据,存在用户名和密码都相同的账户,造成接口上一些问题,SQL语句如下: and Account2>;