我想分拆ascii文本
1 'K\^o, Suk\'e',它被打印为Python字符串。
line = "1 'K\\^o, Suk\\'e'\n"转到
['1', 'K\\^o, Suk\\'e']shlex.split(line)不起作用,给了一个ValueError("No closing quotation")。
我尝试将以下内容添加到wordchars中:
>>> lexer = shlex.shlex(line)
>>> lexer.wordchars += "\\'"
>>> list(lexer)
['1', "'K\\", '^', 'o', ',', "Suk\\'e'"]但这也不是我的本意。
如果没有报价,一切都如预期的那样工作:
>>> line2= "1 'K\\^o, Suk\\e'\n"
>>> shlex.split(line2)
['1', 'K\\^o, Suk\\e']怎么解决这个问题呢?
编辑:我最接近的是:
>>> lexer = shlex.shlex(line)
>>> lexer.wordchars += "\\'"
>>> lexer.wordchars += " "
>>> lexer.wordchars += "\\^"
>>> lexer.wordchars += ","
>>> list(lexer)
['1', "'K\\^o,", "Suk\\'e'"]但还是不对。
编辑:示例字符串有点误导。它也应该能够分裂,比如说
>>> l1 = "C12 H2 'Hello friend'"shlex得到了l1,没问题。
发布于 2016-06-14 15:46:30
您可以使用posix模式和escapedquotes来实现'",而不仅仅是"。
>>> line = "1 'K\\^o, Suk\\'e'\n"
>>> lexer = shlex.shlex(line, posix=True)
>>> lexer.escapedquotes = "'\""
>>> list(lexer)
['1', "K\\^o, Suk'e"]发布于 2016-06-14 14:36:02
对拆分使用正则表达式可能更简单。在任何空格之前,这个标记将分裂为第一个令牌,后面是字符串的其余部分。
re.match('(\S+)\s+(.*)', line).groups()https://stackoverflow.com/questions/37814808
复制相似问题