python 迭代器打印的问题
有如下的代码:import re
>>>p1 = re.compile('\d+')
>>>m2 = p1.findall('3植物故意,7只王八,19只鸭子')
>>>for each in m2:
print(each.group())
>>>
3
7
19
>>>for each in m2:
print(each.group())
当执行第二次for循环的时候, 为何没有输出了? 你这里是使用的 `re.findall()` 方法来查找所有匹配的数字,`findall()` 返回的是一个列表而不是迭代器。因此,你不需要使用 `group()` 方法来获取值,因为每个元素已经是字符串格式。你的代码在第一次循环中运行时没有报错只是因为 `print(each)` 仍然有效,但如果使用 `group()` 会报错,因为字符串没有 `group()` 方法。下面是修正后的代码:
import re
p1 = re.compile('\d+')
m2 = p1.findall('3植物故意,7只王八,19只鸭子')
for each in m2:
print(each)
for each in m2:
print(each)
这样,第二次循环也会正常输出。注意:如果你用的是迭代器而不是列表,迭代器在访问完所有元素后是不可重复使用的。建议用列表保存结果,以便多次访问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 FishC 发表于 2024-12-1 21:52
你这里是使用的 `re.findall()` 方法来查找所有匹配的数字,`findall()` 返回的是一个列表而不是迭代器。因 ...
为什么迭代器在访问完所有元素后是不可重复使用?能解释下具体原因么? 鬼少 发表于 2024-12-01 21:56
为什么迭代器在访问完所有元素后是不可重复使用?能解 ...
迭代器在访问完所有元素后不可重复使用的原因是:
1. **一次性消费**: 迭代器是一种一次性消费的对象。当你从迭代器中获取数据时,它会从第一个元素开始,直到最后一个元素。在迭代的过程中,迭代器内部维护的当前位置会向前移动,并且一旦元素被访问,就不能倒回去访问。
2. **没有重置功能**: 迭代器没有内置的重置功能,它不像列表,可以通过索引来随时访问任何元素。对于迭代器来说,一旦数据流动过,就不能再重新流动。
首次迭代完整个迭代器之后,它就会“耗尽”,这就是为什么在使用 `for` 循环或者手动调用 `next()` 函数消耗完一次后就不能再使用。这个特性允许迭代器节省内存,因为它不必保存整个序列,只需在每次迭代时生成下一个元素。
如果你需要多次遍历相同的数据,可以将迭代器的结果转换为列表(或其他可迭代的对象),例如:
m2 = list(p1.finditer('3植物故意,7只王八,19只鸭子'))
这样做就可以多次遍历 `m2`。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页:
[1]