分拣快递信息练习出错
一个练习,把各个快递信息按省份拣到一起,不知道为什么总是有一部分未能分拣出来快递信息是一个二维列表,里面的每个列表包括姓名和地址,我的思路是先把地址的省份提取到一个集合再转成列表
通过循环每个省份将同一个省份的人合到一个列表,最终将省份和对应列表组成字典
但是现在不知道为什么有一部分不能识别,我将被提取的从原列表删除,最后原列表还剩一部分未能识别
请帮我看看出了什么问题
有80个数据没有识别成
client_massage_list就是上面一堆的信息二维列表
https://s1.ax1x.com/2022/11/20/zKXYpn.png
本帖最后由 jackz007 于 2022-11-20 15:31 编辑
由于列表在循环中有元素被删除,所以,循环必须使用列表的副本,否则,就会出现删除不干净的问题
for every_client in client_message_list[:] : # 循环必须使用列表的副本【代码有修改】
. . . . . .
client_message_list . remove(every_client) # 列表在循环中有元素删除
还有,我看见列表 province 中出现了 2 个新疆,所以,枚举 province 的循环(第 462 行)得使用 set(province)
for every_province in set(province) : #【代码有修改】
还有,下面这一句(465行)
if every_province in every_client :
如果在地址当中包含有一个以上的省名,比如,"上海市xxx新疆路xxx" 或者 "青海xxx北京市驻青办事处xxx" 应该怎么办?为了防止出现误判的情况,必须改为下面这样:
if every_client[: len(every_province)] == every_province : #【代码有修改】
这样改就不会出现问题了
还有,下一回记得一定要贴代码文本 jackz007 发表于 2022-11-20 12:22
由于列表在循环中有元素被删除,所以,循环必须使用列表的副本,否则,就会出现删除不干净的 ...
明白了,谢谢谢谢
页:
[1]