一.数据补充
我们前期的时候和大家说了,有些方法我们放在数据类型补充的这一天中,我们今天将前面没有讲解的内容,都一起讲解了,就先从str开始
str:
1.1 首字母大写
name = "meet"
name.capitalize()
1.2 每个单词的首字母大写
name = "meet"
name.title()
1.3 大小写反转
name = "meet"
name.swapcase()
1.4 统计
name = "meet"
name.count()
1.5 查找
name = "meet"
name.find() # 当查找的时候数据不存在返回-1
name = "meet"
name.index() # 当查找的时候数据不存在报错
1.6 居中
name = "meet"
name.center(20) # 居中一共占用20个位置
1.7 填充
name = "meet{},{},{}"
name1 = name.format("郭宝元","宝帅","宝哥") # 按照位置顺序填充
print(name1)
name = "meet{0},{1},{2}"
name2 = name.format("宝帅","宝哥","郭宝元") # 按照下标填充
print(name2)
name = "meet{a},{c},{b}"
name3 = name.format(a="郭宝元",b="宝帅",c="宝哥") # 按照关键字填充
print(name3)
1.8 拼接 将可迭代容器转换成字符串 字典拼接的是键
可迭代容器中的元素必须是字符串类型
lst = ["2","3","4","5"]
print('*'.join(lst))
tu = ("2","3","4","5")
print('*'.join(tu))
dic = {"key1":2,"key2":4}
print('*'.join(dic))
se = {"1","3","34"}
print('*'.join(se))
字符+
name1 = "alex"
name2 = "wusir"
print(id(name1))
print(id(name2))
print(id(name1 + name2))
字符*
name1 = "alex"
print(id(name1))
print(id(name1 * 5))
字符 + 和 * 都是开辟新的空间
list:
1.1 反转
lst = [1,2,3,4,5]
lst.reverse()
1.2 排序
lst = [1,2,3,4,5]
lst.sort() # 升序
lst.sort(reverse=True) # 降序
1.3 查找
lst = [1,2,3,4,5]
lst.index(3) # 存在就返回索引,不存在就报错
1.4 统计
lst = [1,23,4,5,6,]
lst.count(23) # 统计23出现的次数
list +
lis = [1,2,3]
lst1 = [4,5,6]
print(id(lis))
print(id(lst1))
print(id(lis + lst1))
list *
lst = [1,2,3]
print(lst * 5)
print(id(lst))
print(id(lst * 5))
面试题:
lst = [[]]
new_lst = lst * 5
new_lst[0].append(1)
print(new_lst)
列表在进行乘法的时候元素都是共用
tuple:
面试题:
tu = (1) # 获取的括号中元素的本身
tu = (1,2)# 获取的是元组
tu = (1,) # 获取的是元组
列表能够支持+,* 元组也可以支持+,*
+
tu = (1,2)
tu1 = (3,4)
tu2 = tu + tu1
print(id(tu))
print(id(tu1))
print(id(tu2))
*
tu = ([],)
tu1 = tu * 5
tu1[0].append(9)
print(tu1)
列表在进行乘法的时候元素都是共用
tu = (1,2)
tu1 = tu * 5
print(tu1)
print(id(tu1[0]),id(tu1[-2]))
dict:
字典定义方式:
dict(key=1,key1=2,key2=3)
1.1 随机删除
dic = {"key":"value","key2":"value2"}
dic.popitem() # 随机删除
此处说明一下,官方文档中表示是随机删除一个键值对中,但是我们实际测试的时候
都是删除字典中最后的一个键值对,这也是一个Python36中目前存在的一个bug
1.2 批量创建字典
dic = {}
dic1 = dic.fromkeys("abc",[1,2])
print(dic1)
formkeys这个是个坑,坑点就在于值是可变数据类型的时候,当第一个键对应的值进行修改了以后,其余的键对应的值也都跟着进行改变了. 如何避免坑,就是批量创建字典的时候值不能使用可变的数据类型.
set:
集合定义方式:
set("12345")
{1,2,3,4,5} # 将字符串进行迭代添加
最后我们对我们学习的这些数据类型进行一个总结,我们按照有序,无序,可变,不可变,取值方式来总结
- 有序:
- 数字
- 字符串
- 列表
- 元组
- 无序:
- 字典
- 集合
- 可变数据类型:
- 列表
- 字典
- 集合
- 不可变数据类型:
- 字符串
- 数字
- 元组
- 取值顺序:
- 直接取值 — 数字,布尔值,集合
- 顺序取值(索引) — 列表,元组,字符串
- 通过键取值 — 字典
类型转换
元组 => 列表 list(tuple)
列表 => 元组 tuple(list)
列表 => 字符串 str.join(list)
字符串 => 列表 str.split()
转换成False的数据:
0,'',None,[],(),{},set() 都是False