-
python入门教程之python基础(9):基本数据类型四(set集合)、基础数据类型补充、深浅拷贝
本站最新发布 Python从入门到精通|Python基础教程
试听地址 https://www.xin3721.com/eschool/pythonxin3721/
试听地址 https://www.xin3721.com/eschool/pythonxin3721/
1. 基础数据类型补充
- li = ["李嘉诚", "麻花藤", "⻩海峰", "刘嘉玲"]
- s = "_".join(li)
- print(s)
- li = "⻩花⼤闺⼥"
- s = "_".join(li)
- print(s)
列表:
循环删除列表中的每⼀个元素
- li = [11, 22, 33, 44]
- for e in li:
- li.remove(e)
- print(li)
- 结果:
- [22, 44]
分析原因:
for的运⾏过程,会有⼀个指针来记录当前循环的元素是哪⼀个,⼀开始这个指针指向第0
个,然后获取到第0个元素,紧接着删除第0个。这个时候,原来是第⼀个的元素会⾃动的变成
第0个,然后指针向后移动⼀次,指向1元素,这时原来的1已经变成了0,也就不会被删除了。
⽤pop删除试试看:
- li = [11, 22, 33, 44]
- for i in range(0, len(li)):
- del li[i]
- print(li)
- 结果: 报错
- # i= 0, 1, 2 删除的时候li[0] 被删除之后. 后⾯⼀个就变成了第0个.
- # 以此类推. 当i = 2的时候. list中只有⼀个元素. 但是这个时候删除的是第2个 肯定报错啊
经过分析发现,循环删除都不⾏。不论是⽤del还是⽤remove,都不能实现,那么pop呢?
- for el in li:
- li.pop() # pop也不⾏
- print(li)
- 结果:
- [11, 22]
只有这样才是可以的:
- for i in range(0, len(li)): # 循环len(li)次, 然后从后往前删除
- li.pop()
- print(li)
或者,⽤另⼀个列表来记录你要删除的内容,然后循环删除
- li = [11, 22, 33, 44]
- del_li = []
- for e in li:
- del_li.append(e)
- for e in del_li:
- li.remove(e)
- print(li)
注意: 由于删除元素会导致元素的索引改变,所以容易出现问题,尽量不要再循环中直接去删
除元素,可以把要删除的元素添加到另⼀个集合中然后再批量删除。
dict中的fromkey(),可以帮我们通过list来创建⼀个dict
- dic = dict.fromkeys(["jay", "JJ"], ["周杰伦", "麻花藤"])
- print(dic)
- 结果:
- {'jay': ['周杰伦', '麻花藤'], 'JJ': ['周杰伦', '麻花藤']}
前⾯列表中的每⼀项都会作为key,后⾯列表中的内容作为value,⽣成dict
好了。注意:
- dic = dict.fromkeys(["jay", "JJ"], ["周杰伦", "麻花藤"])
- print(dic)
- dic.get("jay").append("胡⼤")
- print(dic)
- 结果:
- {'jay': ['周杰伦', '麻花藤', '胡⼤'], 'JJ': ['周杰伦', '麻花藤', '胡⼤']}
代码中只是更改了jay那个列表,但是由于jay和JJ⽤的是同⼀个列表。所以,前⾯那个改了. 后
⾯那个也会跟着改
dict中的元素在迭代过程中是不允许进⾏删除的
栏目列表
最新更新
如何使用OS模块中的stat方法
Python os 模块
seek() 方法
python打开文件实例1
Python写入文件
什么是流?
文件操作如何进制逐行读取
Python相对路径
with创建临时运行环境
Python文件操作
.Net Standard(.Net Core)实现获取配置信息
Linux PXE + Kickstart 自动装机
Shell 编程 基础
Shell 编程 条件语句
CentOS8-网卡配置及详解
Linux中LVM逻辑卷管理
1.数码相框-相框框架分析(1)
Ubuntu armhf 版本国内源
Linux中raid磁盘阵列
搭建简易网站
access教程之Access简介
mysql 安装了最新版本8.x版本后的报错:
Mysql空间数据&空间索引(spatial)
如何远程连接SQL Server数据库的图文教程
复制SqlServer数据库的方法
搜索sql语句
sql中返回参数的值
sql中生成查询的模糊匹配字符串
数据定义功能
数据操作功能