enumerate()函数提前统计元素吗?
为了支持对集合的索引,Python 提供了一个叫做 enumerate() 的函数。这个函数可以让你在遍历集合时同时获取到每个元素的索引。
for index, item in enumerate(list):
# do domething
print index
在我的情况下,我有一个非常大的列表,我在想手动创建索引是否比使用 enumerate() 更快?比如:
index = 0
for item in list:
# do something
print index
index = index + 1
2 个回答
1
不,enumerate() 并不是在复制你的列表。它接收一个类似于迭代器的东西作为输入,然后返回一个类似于迭代器的东西作为输出,所以它的工作原理和你手动写的例子差不多。
5
enumerate
函数是内置的,它不会提前计算元素的数量。下面是它在 C 语言中的实现代码:
static PyObject *
enum_next(enumobject *en)
{
PyObject *next_index;
PyObject *next_item;
PyObject *result = en->en_result;
PyObject *it = en->en_sit;
next_item = (*it->ob_type->tp_iternext)(it);
if (next_item == NULL)
return NULL;
next_index = PyInt_FromLong(en->en_index);
if (next_index == NULL) {
Py_DECREF(next_item);
return NULL;
}
en->en_index++;
if (result->ob_refcnt == 1) {
Py_INCREF(result);
Py_DECREF(PyTuple_GET_ITEM(result, 0));
Py_DECREF(PyTuple_GET_ITEM(result, 1));
} else {
result = PyTuple_New(2);
if (result == NULL) {
Py_DECREF(next_index);
Py_DECREF(next_item);
return NULL;
}
}
PyTuple_SET_ITEM(result, 0, next_index);
PyTuple_SET_ITEM(result, 1, next_item);
return result;
}
所以,这个函数会动态地生成下一个 en
整数。