Day-04 基础数据类型list, tuple

 

一、列表

  1.1  列表的介绍

    列表是能装对象的对象,有顺序的(按照我们添加的顺序保存)。

    在代码中使用[ ]表示列表,列表可以放任意的数据,每一项数据与数据之间用逗号隔开

  1.2  列表的索引和切片

    列表同样也拥有索引和切片:

 

lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"]
print(lst[0]) #获取第一个元素
print(lst[1])
print(lst[2])

lst[3] = "流动强"  
print(lst)  #["麻花藤", "王剑林", "马芸", "流动强",  "周鸿医", "向华强"]

s0 = "向华强"
s0[1] = "" # TypeError: 'str' object does not support item assignment 不允许改变
print(s0)
数字、字符串、元组是不可变的

 

 

列表的切片:

 

lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"]
print(lst[0:3])  # ['麻花藤', '王剑林', '马芸']
print(lst[:3])    # ['麻花藤', '王剑林', '马芸']
print(lst[1::2]) # ['王剑林', '周鸿医'] 也有步长
print(lst[2::-1]) # ['马芸', '王剑林', '麻花藤'] 也可以倒着取
print(lst[-1:-3:-2]) # 倒着带步长

1.3  列表的增删改查

    list和str是不一样的,list可以发生改变,所以直接就在原来的对象上进行了操作

    1.增

lst = ["西游记", "红楼梦", "水浒传"]
print(lst)
lst.append("三国演义")
print(lst)   #['西游记', '红楼梦', '水浒传', '三国演义']

#插入
lst = ["西游记", "红楼梦", "水浒传"]
lst.insert(1, "三国演义")
print(lst)  #['西游记', '三国演义', '红楼梦', '水浒传']

#迭代添加
lst = ["西游记", "水浒传"]
lst.extend(["三国演义", "红楼梦"])
print(lst)  #['西游记', '水浒传', '三国演义', '红楼梦']


list = ["孙悟空","小子","帅哥","少年包青天"]
list.extend("刘能")
list.extend(["刘能"])
print(list)
 

 

 

2. 删

lst = ["西游记", "红楼梦", "水浒传", "三国演义", "斗破苍穹"]
print(lst)
deleted = lst.pop()
print("被删除的", deleted) #被删除的 斗破苍穹
print(lst) #['西游记', '红楼梦', '水浒传', '三国演义']

el = lst.pop(2)
print(el) #水浒传
print(lst) #['西游记', '红楼梦', '三国演义']

lst.remove("西游记")
print(lst) #['红楼梦', '三国演义']
# lst.remove("哈哈") # 删除不存在的元素会报错
# # print(lst)

lst.clear() #清空list
print(lst)  #[]

#切片删除
lst = ["西游记", "红楼梦", "水浒传", "三国演义", "斗破苍穹"]
del lst[1:3]
print(lst)  #['西游记', '三国演义', '斗破苍穹']

3. 改

    索引切片修改

 

# 修改
lst = ["太白", "太黑", "五色", "银王", "⽇天"]
lst[1] = "太污" # 把1号元素修改成太污
print(lst)
lst[1:4:3] = ["麻花藤", "哇靠"] # 切片修改也OK. 如果步⻓不是1, 要注意. 元素的个
print(lst)
lst[1:4] = ["李嘉诚个有钱人"] # 如果切片没有步长或者步长是1. 则不用关心这个数
print(lst)

4. 查

    列表是一个可迭代对象。所以可以进行for循环

 

 for el in lst:
      print(el)

 

list = ["jiquan","bajie","danping","yihan"]
for i in range(len(list)):
print(list[i],i)

 

 

1.4  列表的常用功能

lst = ["太白", "太黑", "五色", "银王", "日天", "太白"]
c = lst.count("太白")   #查询太白出现的次数
print(c)   # 2

lst = [1, 5, 88, 9, 87, 0]
lst.sort()    #排序 , 默认升序
print(lst)    #[0, 1, 5, 9, 87, 88]
lst.sort(reverse=True)  #降序
print(lst)    #[88, 87, 9, 5, 1, 0]

lst = ["太白", "太黑", "五色", "银王", "日天", "太白"]
print(lst)
lst.reverse()    #反转
print(lst)    #['太白', '日天', '银王', '五色', '太黑', '太白']

l = len(lst)  # 列表的长度
print(l)

 

 

1.5  列表的嵌套

    采用降维操作,一层一层的看就好

 

lst = [1, "太白", "wusir", ["马虎疼", ["可口可乐"], "王剑林"]]
# 找到wusir
print(lst[2])

# 找到太白和wusir
print(lst[1:3])

# 找到太白的白字
print(lst[1][1])

# 将wusir拿到. 然后首字母大写. 再扔回去
s = lst[2]
s = s.capitalize()
lst[2] = s
print(lst)

# 简写
lst[2] = lst[2].capitalize()
print(lst)

# 把太白换成太黑
lst[1] = lst[1].replace("", "")
print(lst)

# 把马虎疼换成马化疼
lst[3][0] = lst[3][0].replace("", "")
print(lst[3][0])

lst[3][1].append("雪碧")
print(lst)

 

 

二、元组

  俗称不可变的列表,又被称为只读列表,由()组成,里面可以放任何的数据类型。

  元组可以查询,循环,切片,但就是不能改。

  特点:不可变      

  注意:这里元组的不可变的意思是子元素不可变,而子元素内部的子元素是可以变,这取决于子元素是否是可变对象。

  元组中如果只有一个元素。一定要添加一个逗号, 否则就不是元组

 

1 tu = (1)
2 print(type(tu))   #<class 'int'>
3 tu = (1,)
4 print(type(tu))   #<class 'tuple'>

 

 

三、range

  range可以帮我们获取到一组数据,通过for循环能够获取到这些数据

  range(n) : [0,n)

  range(m, n) :[m,n)

  range(m, n, p) :从m到n,没隔p个取一个

 

posted @ 2019-01-09 23:43  行者Sun  阅读(151)  评论(0编辑  收藏  举报