gpt4 book ai didi

python - 是否有可能在 Python 正则表达式中将数组作为一个匹配组

转载 作者:太空狗 更新时间:2023-10-30 02:53:20 29 4
gpt4 key购买 nike

我有以下字符串:

Members: {'name': A, 'age': 30, 'gender': M, 'height': 1.56}, {'name': C, 'age': 20, 'gender': M, 'height': 1.8}, {'name': H, 'age': 45, 'gender': M, 'height': 1.97}, {'name': D, 'age': 23, 'gender': M, 'height': 1.68}; Place: 1//Members: {'name': S, 'age': 33, 'gender': M, 'height': 1.4}, {'name': C, 'age': 19, 'gender': M, 'height': 1.67}, {'name': A, 'age': 44, 'gender': M, 'height': 1.92}, {'name': C, 'age': 33, 'gender': M, 'height': 1.57}; Place: 2

我想知道是否有可能/如何进行匹配:

[['30', '20', '45', '23', '1'], ['33', '19', '44', '33', '2']] or

[(['30', '20', '45', '23'], '1'), (['33', '19', '44', '33'], '2')]

或类似的东西(结果结构并不重要)我只需要有一个地方的所有年龄。我知道我可以迭代拆分并为每个部分或类似解决方案应用正则表达式,但我的问题是是否有办法使用正则表达式来完成一次(一步)...

我会使用 findall 来获取所有“完全匹配项”。我的问题是将“元组”的第一个参数作为数组...

如果我这样做:

r = re.compile("'age': (\d+).*?; Place: (\d+).*?//")
g = r.findall("Members: {'name': A, 'age': 30, 'gender': M, 'height': 1.56}, {'name': C, 'age': 20, 'gender': M, 'height': 1.8}, {'name': H, 'age': 45, 'gender': M, 'height': 1.97}, {'name': D, 'age': 23, 'gender': M, 'height': 1.68}; Place: 1//Members: {'name': S, 'age': 33, 'gender': M, 'height': 1.4}, {'name': C, 'age': 19, 'gender': M, 'height': 1.67}, {'name': A, 'age': 44, 'gender': M, 'height': 1.92}, {'name': C, 'age': 33, 'gender': M, 'height': 1.57}; Place: 2")

我只能得到第一个年龄,然后是位置...

g
[('30', '1')]

最佳答案

据我所知,RegEx 不够强大,无法将一个带有量词的捕获组的命中存储在列表中,然后是另一个捕获组。

下面只执行一次 RegEx 搜索和一次循环,但我承认它不是很漂亮。

import re

r = re.compile("(age|Place)'?: (\d+)")

g = r.finditer("Members: {'name': A, 'age': 30, 'gender': M, 'height': 1.56}, {'name': C, 'age': 20, 'gender': M, 'height': 1.8}, {'name': H, 'age': 45, 'gender': M, 'height': 1.97}, {'name': D, 'age': 23, 'gender': M, 'height': 1.68}; Place: 1//Members: {'name': S, 'age': 33, 'gender': M, 'height': 1.4}, {'name': C, 'age': 19, 'gender': M, 'height': 1.67}, {'name': A, 'age': 44, 'gender': M, 'height': 1.92}, {'name': C, 'age': 33, 'gender': M, 'height': 1.57}; Place: 2")

ages = []
ranks = {}
for m in g:
if m[1] == 'age':
ages.append(m[2])
else:
ranks[m[2]] = ages
ages = []

print(ranks)

基本上只捕获任何年龄或地点,遍历比赛。将所有年龄存储到一个列表中,直到我们遇到一个地点,在这种情况下,我们使用前一个列表作为值,并将地点作为字典中的键。然后我们重置列表并重新开始。

当然需要注意的是,地点总是时代之后。

关于python - 是否有可能在 Python 正则表达式中将数组作为一个匹配组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49987288/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com