ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

删除空条目并将其添加为列表的上一个条目中的空格

2019-10-28 21:58:17  阅读:209  来源: 互联网

标签:list split whitespace string python


我目前正在一个项目中,该项目需要拆分句子,以便将两个单词(用户需要输入的给定单词,给我们第二个单词)彼此进行比较,并检查用户键入的准确性.我一直在使用x.split(“”)来执行此操作,但是,这给我带来了问题.

假设给定的句子是The quick brown fox,用户输入The quick brown fox.
而不是返回[‘The’,’quick’,’brown’,’fox’],而是返回[‘The’,’quick’,’,’brown’,fox’].这使检查准确性变得更加困难,因为我希望逐个单词地对其进行检查.

换句话说,我想在前面的单词后面添加任何多余的空格,但是split函数创建的是单独的(空)元素.如何删除所有空条目并将其添加到它们前面的单词?

我希望这适用于同时存在多个”条目的列表,例如[‘The’,’quick’,”,’,’,’brown’,fox’].

谢谢!

编辑-我用来测试此代码只是x的一些变体=快速棕狐“ .split(”),具有不同的空格.

编辑2-我没有考虑这一点(感谢Malonge),但是如果句子以空格开头,我实际上也希望将其计算在内.我不知道这样做有多容易,因为我需要使这个特定实例成为例外,在该例外情况下,需要在其后的单词而不是其前面的单词后面添加空格.但是,由于难以实现,因此我在计算精度时会做出明智的选择,以忽略该情况.

解决方法:

您可以为此使用正则表达式,这将匹配第一个空格之后的所有空格:

>>> import re
>>> s = "The quick  brown fox"
>>> re.findall(r'\S+\s*(?=\s\S|$)', s)
['The', 'quick ', 'brown', 'fox']

Debuggex Demo

\S+\s*(?=\s\S|$)

更新:

为了匹配字符串开头的前导空格,需要对上述正则表达式进行一些修改:

>>> s = "The quick  brown fox"
>>> re.findall(r'((?:(?<=^\s)\s*)?\S+\s*(?=\s\S|$))', s)
['The', 'quick ', 'brown', 'fox']
>>> s1 = "  The quick  brown fox"
>>> re.findall(r'((?:(?<=^\s)\s*)?\S+\s*(?=\s\S|$))', s1)
[' The', 'quick ', 'brown', 'fox']

Debuggex Demo

((?:(?<=^\s)\s*)?\S+\s*(?=\s\S|$))

标签:list,split,whitespace,string,python
来源: https://codeday.me/bug/20191028/1955331.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有