本问题已经有最佳答案,请猛点这里访问。
我对这个代码有两个问题。首先,它不会删除列表行末尾的''。所以我试着打印X来看看到底发生了什么,但是我遇到了第二个问题,那就是X不能被打印出来。似乎有些断行和"51"被打印出来了,但为什么只有那些而不是其他?
怎么会这样?我完全不知道。
编辑:这不是副本。我想知道为什么它不能删除,但为什么它不能打印。@阿兰费在你把问题标记为重复之前先把它读了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38row = ['
', '2017-18 ', '
', 'GSW', '
', '
', '51', '
', '32.0', '
', '26.4', '
', '8.4', '
', '16.9', '
', '49.5', '
', '4.2', '
', '9.8', '
', '42.3', '
', '5.5', '
', '5.9', '
', '92.1', '
', '0.7', '
', '4.4', '
', '5.1', '
', '6.1', '
', '3.0', '
', '1.6', '
', '0.2', '
', '2.2', '
', '43.8', '
', '5', '
', '0', '
', '9.5', '
']
i = 0
for x in row:
print(i,":", x)
if x in ('
', '°', '%'):
row.remove(x)
i+=1
print(row)
它的输出是
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
570 :
1 :
2 :
3 : 51
4 :
5 :
6 :
7 :
8 :
9 :
10 :
11 :
12 :
13 :
14 :
15 :
16 :
17 :
18 :
19 :
20 :
21 :
22 :
23 :
24 :
25 :
26 :
27 :
['2017-18 ', 'GSW', '51', '32.0', '26.4', '8.4', '16.9', '49.5', '4.2', '9.8', '42.3', '5.5', '5.9', '92.1', '0.7', '4.4', '5.1', '6.1', '3.0', '1.6', '0.2', '2.2', '43.8', '5', '0', '9.5', '
']
号
您可以在此处运行此代码:https://repl.it/@leonardchoo/listnotworking
在迭代对象时,不应该修改它。
@Ev.Kounis为什么?
@阿兰费,这个问题不是你提供的一个副本。请去掉重复的标志。在将问题标记为重复之前,请先阅读该问题。
我不明白这是怎么回事。迭代时从列表中删除元素会使循环跳过一些元素。在我链接的问题中都有解释。
在那里,我找到了一个更好的替身。
@阿兰费,谢谢,新的链接是有意义的。如果你仔细阅读我的问题,有两个问题:1。无法删除2。无法打印。你的新链接仍然没有回答第二部分。这意味着这只是复制品的50%。因此,如果你把它标为副本,我的问题可能就得不到足够的重视来得到完整的答案。如果不是完整的副本,请不要将其标记为一个,因为它在任何方面都对我没有帮助。相反,在评论中加上"这可能是……的副本"
它不会被打印,因为循环跳过了一些元素。这与它不被删除的原因完全相同。
@阿兰费现在可以理解了。这些事情对你来说可能是显而易见的,但请记住,这对每个人,尤其是初学者来说并不明显。如果你把它作为答案寄出去,我可以接受
试试这个,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35row = ['
', '2017-18 ', '
', 'GSW', '
', '
', '51', '
', '32.0', '
', '26.4', '
', '8.4', '
', '16.9', '
', '49.5', '
', '4.2', '
', '9.8', '
', '42.3', '
', '5.5', '
', '5.9', '
', '92.1', '
', '0.7', '
', '4.4', '
', '5.1', '
', '6.1', '
', '3.0', '
', '1.6', '
', '0.2', '
', '2.2', '
', '43.8', '
', '5', '
', '0', '
', '9.5', '
']
row = [x for x in row if x not in ['
', '°', '%']]
for i, x in enumerate(row):
print(i, x)
产量
1
2
3
4
5
60 2017-18
1 GSW
...
23 5
24 0
25 9.5
号
谢谢。但你知道为什么我的代码不能删除和打印吗?
最好删除并创建另一个list,而不要在迭代时修改旧的EDOCX1
row = ['', '2017-18 ', '', 'GSW', '', '', '51', '', '32.0', '', '26.4', '', '8.4', '', '16.9', '', '49.5', '', '4.2', '', '9.8', '', '42.3', '', '5.5', '', '5.9', '', '92.1', '', '0.7', '', '4.4', '', '5.1', '', '6.1', '', '3.0', '', '1.6', '', '0.2', '', '2.2', '', '43.8', '', '5', '', '0', '','9.5','']removeelement=["","?","%"]对于列表(行)中的i:如果我在搬迁:行。删除(i)打印(行)