如何解决为什么在程序成功执行第一步时出现IndexError?
我试图制作一个排序器,以删除第一个列表中IP的重复项并将其保存到文件中,但是在第一次成功回合后,它给了我IndexError:列表索引超出范围。
我期望正常的排序过程,但是不起作用
代码:
ip1 = open('hosts','r')
ip2 = open('rotten','r')
ipList1 = [line.strip().split('\n') for line in ip1]
ipList2 = [line.strip().split('\n') for line in ip2]
for i in range(len(ipList1)):
for a in range(len(ipList2)):
if(ipList1[i] == ipList2[a]):
print('match')
del(ipList1[i])
del(ipList2[a])
i -= 1
a -= 1
c = open('end','w')
for d in range(len(ipList1)):
c.write(str(ipList1[d]) + '\n')
c.close()
解决方法
要在列表上进行迭代时将其删除,这就是为什么出现IndexError的原因。
使用sets可以更轻松地完成此操作:
with open('hosts') as ip1,open('rotten') as ip2:
ipList1 = set(line.strip().split('\n') for line in ip1)
ipList2 = set(line.strip().split('\n') for line in ip2)
good = ipList1 - ipList2
with open('end','w') as c:
for d in good:
c.write(d + '\n')
,
您即时更改了列表。例如,对于expression获取一个具有5个元素长度的列表,在第一次迭代后删除4,因此在第二次迭代中尝试提取第二个元素,但现在不存在。
如有必要,可以保存生成顺序,可以使用生成器表达式:
ips = [ip for ip in ipList1 if ip not in set(list2)]
如果没有,则使用集合表达式。
,您永远不要修改当前正在迭代的列表。 解决方法是仅制作第三个保存非重复项的列表。另一种方法是只使用集合并将它们彼此相减,尽管我确实知道您是否喜欢一个列表本身中的重复项。此外,您现在所做的操作只有在索引相同的情况下才找到重复项。
<div class="inputs">
<label for="aimer_larousse_ef_active_10">Conjugaison (voix active)</label>
<input type="checkbox" id="aimer_larousse_ef_active_10" name="trigger" class="trigger">
<label for="aimer_larousse_ef_passive_10">Conjugaison (voix passive)</label>
<input type="checkbox" id="aimer_larousse_ef_passive_10" name="trigger" class="trigger">
<div class="fullverbtable_1">abcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa</div>
<div class="fullverbtable_2">xyzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz</div>
</div>
<div class="para">
</div>
,
其他答案集中在迭代容器时从容器中删除。尽管通常这是一个坏主意,但这并不是问题的症结所在,因为您已经(以非Python方式)设置了for
循环以使用一系列索引,因此您并不是严格来说要遍历列表本身无论如何。
否,这里的问题是i-=1
和a-=1
无效:当for
循环开始新的迭代时,它不会从之前的值开始工作指数。它只是从您一开始就建立的迭代器中取走了它总是注定要取的下一个值(在您的情况下为range()
的输出)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。