我想从命令行接收像“\t”(制表符)这样的分隔符,
并用它来解析文本文件。
如果我把
delimiter = sys.argv[1]
在代码中,然后从命令行输入
$ python mycode.py "\t"
分隔符是'\\t'
即,Python 会按原样保留输入字符串。
我想将其转换为 '\t' 以便我可以使用例如
'a\tb\tc'.split(delimiter)
to get ['a','b','c']
.
我尝试将“\”转换为“\”,但失败了。
是否有内置的 python 函数可以从命令行处理正则表达式?
在Python 2中你可以使用str.decode('string_escape')
:
>>> '\\t'.decode('string_escape')
'\t'
在Python 3中,您必须首先将字符串编码为字节,然后使用unicode_escape
:
>>> '\\t'.encode().decode('unicode_escape')
'\t'
两种解决方案都接受任何转义序列并正确解码它们,因此您甚至可以使用一些奇特的 unicode 东西:
>>> '\\t\\n\\u2665'.encode().decode('unicode_escape')
'\t\n♥'
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)