15
15

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Pythonで空のリストを作るときの注意点

Posted at

Pythonで空リストを作ったときに不思議なことに出会った。

いま、空のリストをN個もつようなリストをつくるとする。

このとき、以下の2つの方法がある。

test.py
l1 = [[]] * N
l2 = [[] for _ in range(N)]

どちらも出力すると同じリストを作成しているように見える。

>>> N = 10
>>> l1 = [[]] * N
>>> l2 = [[] for _ in range(N)]
>>> print(l1)
[[], [], [], [], [], [], [], [], [], []]
>>> print(l2)
[[], [], [], [], [], [], [], [], [], []]

しかし、要素をappendした際に違う挙動を示す。
それぞれのindex = 0 の要素に[1,2]をappendしてみよう。

>>> l1[0].append([1,2])
>>> l2[0].append([1,2])
>>> print(l1)
[[[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]], [[1, 2]]]
>>> print(l2)
[[[1, 2]], [], [], [], [], [], [], [], [], []]

l1 ではすべての要素に対してappendが効いている。
どうやら、append等の操作ではコピー元の要素に対しても更新が及んでしまうらしい。

こうしたややこしいことがあるので、空の配列を作るときは

l = [[] for _ in range(N)]

とするのが無難ですね。

15
15
4

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
15

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?