鱼C论坛

 找回密码
 立即注册
查看: 1810|回复: 8

[已解决]列表推导式的小问题~~~

[复制链接]
发表于 2018-6-12 00:56:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 kerwin_lui 于 2018-6-12 00:57 编辑

目的:   给 L 这个列表去重


代码一:
  1. L = [1, 2, 3, 4, 1, 2, 3, 1, 2, 1]
  2. L2 = []
  3. for i in L:
  4.     if i not in L2:
  5.         L2.append(i)
  6. print(L2)
复制代码

输出:
[1, 2, 3, 4]


代码二:
  1. L = [1, 2, 3, 4, 1, 2, 3, 1, 2, 1]
  2. L2 = []
  3. L2 = [i for i in L if i not in L2]
  4. print(L2)
复制代码

输出:
[1, 2, 3, 4, 1, 2, 3, 1, 2, 1]


问题:
列表推导式和for循环的为什么会有这样的差别, 一直以为这两个等价的。
我猜测是:列表推导式中的 “ if i not in L2 ” 只是在判断上面空的L2,而不是判断添加元素后的L2,可是为什么会这样呢?
最佳答案
2018-6-12 16:24:35
应为L2在for循环的时候L2列表一直是空的,等到循环完毕才更新L2,可以看一下我的截图,你也可以debug看一下。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-6-12 08:46:55 | 显示全部楼层
因为下面的列表推导式必须等推导结束后才更新L2的值,上面的则是实时更新L2
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-12 10:49:59 | 显示全部楼层
本帖最后由 凌九霄 于 2018-6-12 11:03 编辑

你首先认为自己写的推导式是正确的,然后质疑推导式有问题,这就是你的问题。

你一定要用这种方式去重,没有问题,但你不能简单的把上面的for循环转为推导式,因为里面有个实时的append方法你并不能实现

  1. L = [1, 2, 3, 4, 1, 2, 3, 1, 2, 1]

  2. L1 = [L[i] for i in range(len(L)) if L[i] not in L[:i]]

  3. print(L1)
复制代码


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-12 16:24:35 | 显示全部楼层    本楼为最佳答案   
应为L2在for循环的时候L2列表一直是空的,等到循环完毕才更新L2,可以看一下我的截图,你也可以debug看一下。

正在循环

正在循环

循环中L2的状态

循环中L2的状态
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-6-12 22:36:40 | 显示全部楼层
凌九霄 发表于 2018-6-12 10:49
你首先认为自己写的推导式是正确的,然后质疑推导式有问题,这就是你的问题。

你一定要用这种方式去重, ...

感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-6-14 15:38:37 | 显示全部楼层
一般没有特殊要求可以用Python内置的函数set去重。。。
内置函数一般都比自己写的效率高,何况是循环。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-10 14:57:38 | 显示全部楼层
凌九霄 发表于 2018-6-12 10:49
你首先认为自己写的推导式是正确的,然后质疑推导式有问题,这就是你的问题。

你一定要用这种方式去重, ...

第3行代码,没看懂,能详细解释一下吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-10 16:09:08 | 显示全部楼层
13572044595 发表于 2018-9-10 14:57
第3行代码,没看懂,能详细解释一下吗?

还原成一般代码模式,应该可以看懂了
  1. L = [1, 2, 3, 4, 1, 2, 3, 1, 2, 1]

  2. L1 = []
  3. for i in range(len(L)):
  4.     if L[i] not in L[:i]:
  5.         L1.append(L[i])
  6. print(L1)
复制代码

评分

参与人数 1荣誉 +1 鱼币 +1 贡献 +1 收起 理由
13572044595 + 1 + 1 + 1

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2018-9-10 16:12:14 | 显示全部楼层
凌九霄 发表于 2018-9-10 16:09
还原成一般代码模式,应该可以看懂了

好的谢谢,我得好好研究一下~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-3-29 06:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表