首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何消除txt文件中的所有括号?

如何消除txt文件中的所有括号?
EN

Stack Overflow用户
提问于 2017-04-03 09:50:58
回答 2查看 47关注 0票数 0

我有一个txt文件,单列,摘自excel,类型如下:

阿曼达(大声讲话)杰夫史蒂文(开玩笑地)阿曼达DOC布赖恩格林

作为输出,我希望:

阿曼达杰夫史蒂文阿曼达布莱恩格林

我尝试在所有列上使用for循环,然后:

代码语言:javascript
运行
复制
            if (str[i] == '('):  
                return str.split('(')

但显然不起作用。你有什么可能的解决办法吗?然后,我需要一个输出文件作为我的原始txt,因此每一行的每个名称都在一个列中。

谢谢大家!(我使用的是PyCharm 3.2)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-04-03 09:55:38

在这种情况下我会用regex。\w将替换字母,*将选择0或更多。然后我们检查它是否在圆括号之间。

代码语言:javascript
运行
复制
import re
fi = "AMANDA (LOUDLY) JEFF STEVEN (TEASINGLY) AMANDA"
with open("mytext.txt","r") as fi, open("out.txt", "w") as fo:
    for line in fi:
        fo.write(re.sub("\(.*?\)", "", line))
票数 0
EN

Stack Overflow用户

发布于 2017-04-03 10:00:11

可以使用与括号或完整单词中的所有内容匹配的正则表达式将字符串拆分为列表,从包含括号的列表中删除所有元素,然后再次将列表加入到字符串中。优点是在结果字符串中不存在删除parantheses中的一个单词的双空格。

代码语言:javascript
运行
复制
import re
text = "AMANDA (LOUDLY SPEAKING) JEFF STEVEN (TEASINGLY) AMANDA DOC BRIAN GREEN"
words = re.findall("\(.*?\)|[^\s]+",text)
print " ".join([x for x in words if "(" not in x])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43181490

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档