Diez B. Roggisch wrote:
<div class="moz-text-flowed" style="font-family: -moz-fixed">Esmail schrieb:
Could someone help confirm/clarify the semantics of the [:] operator
in Python?

a = range(51,55)

############# 1 ##################
b = a[:] # b receives a copy of a, but they are independent
>


# The following two are equivalent
############# 2 ##################
c = []
c = a[:] # c receives a copy of a, but they are independent

No, the both above are equivalent. Both just bind a name (b or c) to a list. This list is in both cases a shallow copy of a.



############# 3 ##################
d = []
d[:] = a # d receives a copy of a, but they are independent


This is a totally different beast. It modifies d in place, no rebinding a name. So whover had a refernce to d before, now has a changed object, whereas in the two cases above, the original lists aren't touched.

Of course, in your concrete example, the looks of it are the same. The distinction is crucial in larger contexts.

Diez


While Diez is correct, I think it could be less confusing. So I'll try to put it clearer. If it's not, sorry.

(2) binds an empty list to c, and immediately rebinds it to a new list, copied from a.. So the c=[] line is totally irrelevant, unless there's some other code in between.

(3) again binds an empty list to d, but this is important, because the following line wouldn't be legal if there weren't already a list. The only time this has a different practical effect from the other two is if there's some other code between the two lines. If that other code binds something to the same object then it definitely matters.

I'd say (1) is the preferable form, as no visible object is in an in-between state. The copy is built anonymously, then bound only when it has its full value.

DaveA

--
http://mail.python.org/mailman/listinfo/python-list

Reply via email to