基于python for in if 连着写与分开写的区别说明
links.extend(link for link in get_links(html) if re.match(link_regex, link))# 上面的语句分开写,如下# 但下面需要使用links.append,如果依然使用links.extend会出现错误的结果for link in get_links(html): if re.match(link_regex, link): links.append(link)
让我们用ipython做个实验:
由上图可以看出,for in if 连击推导式隐式的将link由str转变为了list,而分开写是不会帮我们转换的,所以需要使用append把整个str加入到list.
补充:python的for i in list 陷阱
d = [1,2,3,4,5]for i in d: d.remove(i)print d
结果是 :
[2, 4]
这个陷阱比较隐蔽,我再用白盒子测试的时候,发现了这个bug,大致原因就是remove d[0]之后,i 自动变成了 d[1], 但是 d已经变成了 d[2,3,4,5],所以i=d[1]就悲催的指向了3,跳过了2!
看来python还是要注意了解底层实现啊!
解决办法是d = [1,2,3,4,5]for i in d[:]: d.remove(i)print d
就可以实现边遍历边删除了
以上为个人经验,希望能给大家一个参考,也希望大家多多支持好吧啦网。如有错误或未考虑完全的地方,望不吝赐教。
相关文章:
1. java实现抽奖功能解析2. python基于scrapy爬取京东笔记本电脑数据并进行简单处理和分析3. Android制作登录页面并且记住账号密码功能的实现代码4. 详解Android跨进程通信之AIDL5. 如何使用Mock修改Android设备上的features6. set rs=conn.execute,set rs=server.createobject(“ADODB.recordset”)的性能对比7. Python ini文件常用操作方法解析8. PHP会话处理函数介绍9. python 基于PYMYSQL使用MYSQL数据库10. opencv-python的RGB与BGR互转方式