【Python Cookbook】S01E18 针对任意多的分隔符拆分字符串

2024-06-04 13:04

本文主要是介绍【Python Cookbook】S01E18 针对任意多的分隔符拆分字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 问题
  • 解决方案
  • 讨论

问题

我们需要将字符串拆分为不同的字段,但是分隔符在整个字符串中不一致,换句话说,就是有很多分隔符,该怎么办?

解决方案

字符串常用拆分方法 xxx.split() 只能处理简单情况,不支持多个分隔符。但是如果使用正则化匹配 re.split('', xxx),则可以将字符串按照多个分隔符进行拆分。

line = 'asdf fjdk; afed, fjek,asdf,  foo'
print(line.split(r' '))
import re
line = 'asdf fjdk; afed, fjek,asdf,  foo'
print(re.split(r'[;,\s]', line))

结果:

['asdf', 'fjdk', '', 'afed', '', 'fjek', 'asdf', '', '', 'foo']

但是至此,我们还应该有两个疑问,

  • 第一,为什么 \s 在字符串的 split() 中不可以,但是在正则化匹配中可以实现按照空格拆分?
  • 第二,现在正则化结果中还包含一些奇怪的元素,这些元素是什么,该怎样清除?

带着这些问题我们进入讨论。

讨论

首先,问题1:为什么 line.split(r'\s') 不能实现按空格拆分?

答: 在普通字符串中,\s 并不是代表空格,而是被解释为反斜杠 \ 和小写字母 s 的组合体 \s

test_arr = "\ask your question\s, please"
print(test_arr.split(r"\s"))

而在正则化中,\s 是一个特殊字符类,用于匹配任何空白字符,包括空格、制表符、换行符等。这是正则表达式语言的一部分,用于简化对文本模式的匹配。

总而言之,

  • 在正则表达式中:\s 表示匹配任何空白字符。
  • 在普通字符串中:' ' 表示一个空格字符,而 \s 表示反斜杠字符 \ 后跟小写字母 s

其次,问题2:为什么结果中出现 “”, 如何清除?

答: 首先,理解如下正则表达式处理结果。

test_arr = "hello,;world"
print(re.split(r"[,;]", test_arr))

结果:

# 我们希望的结果
["hello", "world"]
# 实际得到的结果
['hello', '', 'world']

出现空白字符的原因是,在字符串 test_arr 中,连续的逗号和分号视为两个分隔符,因此 re.split() 做了两次分割,将字符串拆分成如下部分:

  • “hello”:逗号之前的部分。
  • “”:逗号和分号之间的部分(没有字符)。
  • “world”:分号之后的部分。

因此,结果是 [‘hello’, ‘’, ‘world’]
但是我们怎样实现我们期望的结果呢?通过符号 +

test_arr = "hello,;world"
print(re.split(r"[,;]+", test_arr))

其结果为:

['hello', 'world']

+ 的作用,指的是匹配 re.split(pattern, arr) 模式 pattern 中所有指定的分隔符的一个或者多个符号的组合。让我们使用复杂一些的代码更多测试:

test_arr = "hello,;world,hi;child;,;test"
print(re.split(r"[,;]+", test_arr))

结果为:

['hello', 'world', 'hi', 'child', 'test']

最后,回到本题目,如果我们希望能够成功得到如

['asdf', 'fjdk', 'afed', 'fjek', 'asdf', 'foo']

的结果,根据上述内容,我们可以将 pattern 改写为

print(re.split(r'[;,\s]+', line))# 输出结果为
['asdf', 'fjdk', 'afed', 'fjek', 'asdf', 'foo']

这篇关于【Python Cookbook】S01E18 针对任意多的分隔符拆分字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030160

相关文章

2390.从字符串中移除星号

给你一个包含若干星号 * 的字符串 s 。 在一步操作中,你可以: 选中 s 中的一个星号。 移除星号左侧最近的那个非星号字符,并移除该星号自身。 返回移除 所有 星号之后的字符串。 注意: 生成的输入保证总是可以执行题面中描述的操作。 可以证明结果字符串是唯一的。 示例 1: 输入:s = “leet**cod*e” 输出:“lecoe” 解释:从左到右执行移除操作: 距离第 1 个

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的

python 在pycharm下能导入外面的模块,到terminal下就不能导入

项目结构如下,在ic2ctw.py 中导入util,在pycharm下不报错,但是到terminal下运行报错  File "deal_data/ic2ctw.py", line 3, in <module>     import util 解决方案: 暂时方案:在终端下:export PYTHONPATH=/Users/fujingling/PycharmProjects/PSENe

将一维机械振动信号构造为训练集和测试集(Python)

从如下链接中下载轴承数据集。 https://www.sciencedirect.com/science/article/pii/S2352340918314124 import numpy as npimport scipy.io as sioimport matplotlib.pyplot as pltimport statistics as statsimport pandas