首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >shlex: Python 3中的转义引号

shlex: Python 3中的转义引号
EN

Stack Overflow用户
提问于 2016-06-14 14:24:52
回答 2查看 3.4K关注 0票数 3

我想分拆ascii文本

代码语言:javascript
复制
1 'K\^o, Suk\'e'

,它被打印为Python字符串。

代码语言:javascript
复制
line = "1 'K\\^o, Suk\\'e'\n"

转到

代码语言:javascript
复制
['1', 'K\\^o, Suk\\'e']

shlex.split(line)不起作用,给了一个ValueError("No closing quotation")

我尝试将以下内容添加到wordchars中:

代码语言:javascript
复制
>>> lexer = shlex.shlex(line)
>>> lexer.wordchars += "\\'"
>>> list(lexer)
['1', "'K\\", '^', 'o', ',', "Suk\\'e'"]

但这也不是我的本意。

如果没有报价,一切都如预期的那样工作:

代码语言:javascript
复制
>>> line2= "1 'K\\^o, Suk\\e'\n"
>>> shlex.split(line2)
['1', 'K\\^o, Suk\\e']

怎么解决这个问题呢?

编辑:我最接近的是:

代码语言:javascript
复制
>>> lexer = shlex.shlex(line)
>>> lexer.wordchars += "\\'"
>>> lexer.wordchars += " "
>>> lexer.wordchars += "\\^"
>>> lexer.wordchars += ","
>>> list(lexer)
['1', "'K\\^o,", "Suk\\'e'"]

但还是不对。

编辑:示例字符串有点误导。它也应该能够分裂,比如说

代码语言:javascript
复制
>>> l1 = "C12 H2 'Hello friend'"

shlex得到了l1,没问题。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-06-14 15:46:30

您可以使用posix模式和escapedquotes来实现'",而不仅仅是"

代码语言:javascript
复制
>>> line = "1 'K\\^o, Suk\\'e'\n"
>>> lexer = shlex.shlex(line, posix=True)
>>> lexer.escapedquotes = "'\""
>>> list(lexer)
['1', "K\\^o, Suk'e"]
票数 2
EN

Stack Overflow用户

发布于 2016-06-14 14:36:02

对拆分使用正则表达式可能更简单。在任何空格之前,这个标记将分裂为第一个令牌,后面是字符串的其余部分。

代码语言:javascript
复制
re.match('(\S+)\s+(.*)', line).groups()
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37814808

复制
相关文章

相似问题

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