我有以下内容:
str = '[5.955894, 45.817792], [10.49238, 45.817792], [10.49238, 47.808381], [5.955894, 47.808381]'
我想把它拆分成一个字符串数组,比如
['[5.955894, 45.817792]', '[10.49238, 45.817792]', ...]
因此 [...]
对象是数组的元素。包含封闭的 [
和 ]
很重要。我已经走了这么远:
re.split('\D,\s\D', str)
但这给了我:
['[5.955894, 45.817792', '10.49238, 45.817792', '10.49238, 47.808381', '5.955894, 47.808381]']
最佳答案
我更喜欢使用 re.findall
并指定我想要的 而不是试图描述 re.split
的分隔符
>>> s = '[5.955894, 45.817792], [10.49238, 45.817792], [10.49238, 47.808381], [5.955894, 47.808381]'
>>> re.findall(r"\[[^\]]*\]",s)
['[5.955894, 45.817792]', '[10.49238, 45.817792]', '[10.49238, 47.808381]', '[5.955894, 47.808381]']
\[
匹配 [[^\]]*
匹配除 ] 之外的任何内容\]
匹配 ]
关于python - 将嵌套列表的字符串表示拆分为子列表的字符串表示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14814186/