重複の可能性:
1つとして機能する2つの別々のPythonリスト
このコードはリストの辞書を作成し、キーはにありますusens
。リストは0
sでいっぱいです
usens = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14, 110, 111, 112, 113, 114,
115, 116, 117, 118, 119, 302, 303, 306, 307, 308, 370, 371, 500,
501, 1000, 1010, 1020, 1100, 1200, 1201, 1202, 2000, 2001, 2002
]
empty = [[0]*length]*len(usens)
data = dict(zip(usens, empty))
pprint.pprint(data, indent=5)
data[0][0] += 1
pprint.pprint(data, indent=5)
最初のきれいな印刷物は期待されたものを返します(宣伝文句は削除されました):
{0: [0, 0, 0, 0, 0],
1: [0, 0, 0, 0, 0],
2: [0, 0, 0, 0, 0],
3: [0, 0, 0, 0, 0],
4: [0, 0, 0, 0, 0],
5: [0, 0, 0, 0, 0],
.....
2001: [0, 0, 0, 0, 0],
2002: [0, 0, 0, 0, 0]}
次に、これを行います。 、(インデックスの)最初のリストがで始まることをdata[0][0] += 1
期待しますが、他に変更するものはありません。0
1
ただし、すべてのリストが変更されています。
{0: [1, 0, 0, 0, 0],
1: [1, 0, 0, 0, 0],
2: [1, 0, 0, 0, 0],
3: [1, 0, 0, 0, 0],
4: [1, 0, 0, 0, 0],
.....
2001: [1, 0, 0, 0, 0],
2002: [1, 0, 0, 0, 0]}
なぜ、そしてどうすれば1つのリストだけが変更されるようにできますか?