Python 如何像 awk一样分割字符串?

域名2025-11-05 10:54:4919313

若你使用过 Shell 中的何像 awk 工具,会发现用它来分割字符串是分割非常方便的。特别是字符多个连续空格会被当做一个处理。

[root@localhost ~]# cat demo.txt hello      world [root@localhost ~]# [root@localhost ~]# awk {print$1,何像$2} demo.txt hello world 

可是转换到 Python 上面来呢?结果可能是这样的。

>>> msg=hello    world >>> msg.split( ) [hello,分割 , , , world] 

与我预想的结果不符,多个空格会被分割多次。字符

那有什么办法可以达到 awk 一样的何像效果呢?

有两种方法。源码库

第一种方法

不加参数,分割这种只适用于将多个空格当成一个空格处理,字符如果不是何像以空格为分隔符的场景,这种就不适用了。分割

>>> msg=hello    world >>> msg.split() [hello,字符 world] 

第二种方法

使用 filter 来辅助,这种适用于所有的何像分隔符,下面以 - 为分隔符来举例。分割

>>> msg=hello----world >>> msg.split(-) [hello,字符 , , , world] >>> >>> filter(None, msg.split(-)) [hello, world] 

是不是很神奇,filter 印象中第一个参数接收的是香港云服务器 函数,这里直接传 None 居然有奇效。

查看了注释,原来是这个函数会适配 None 的情况,当第一个参数是None的时候,返回第二个参数(可迭代对象)中非空的值,非常方便。

换用函数的写法,可以这样

>>> msg=hello----world >>> msg.split(-) [hello, , , , world] >>> >>> filter(lambda item: True if item else False, msg.split(-)) [hello, world] b2b供应网
本文地址:http://www.bhae.cn/news/989e20498806.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

热门文章

全站热门

探索小创客教育的创新之路(培养创造力和实践能力的小创客教育模式)

MySQL数据库集群进行正确配置步骤

MySQL分页查询通用存储过程的代码总结

MySQL数据库权限设置的实际运行过程

华为荣耀3Outdoor——探索极限,尽显荣耀(适合户外探险的智能手机,华为荣耀3Outdoor值得拥有)

MySQL数据库如何从相关表中取出随机数据?

MySQL5中经常出现的字符集问题有哪些?

MySQL5中的字符集问题与破解方案

热门文章

友情链接

滇ICP备2023000592号-9