基本数据类型(list,tuple)
主要内容:
1,列表
2,列表的增删改查
3,列表的嵌套
4,元组和元组嵌套
5,range
列表
列表的介绍
列表是python的几本书类型之一,其他编程语言也有类似的数据类型,它是以[ ]括起来,
每个元素用','隔开而且可以存储各种数据类型
lst = [1, '哈哈', "吼吼", [1,8,0,"百度"], ("我","叫", "元", "组"), "abc", {"我叫":"dict字典"},{"我叫集合","集合"}]
列表的索引和切片
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,增,注意,list和str不一样,list可以改变,所以直接在原来的岁向上进行操作
lst = ["mahateng", "linjunjie", "zhourunfa", "zhouzhiruo"] print(lst) lst.append("wusir") print(lst) lst = [] while True: content = input("请输入你要录入的员工信息,输入Q推出") if content.upper() == "Q": break lst.append(content) print(lst) lst = ["chenrun", "刘德华", "孔夫子"] lst.insert(1, "马云") print(lst) # 迭代增加 lst = ["金志文", "张一山", "周杰伦"] lst.extend(["何炅", "黄渤"]) print(lst)
删除
pop,remove,clear,del
lst = ["陈润", "王健林", "李嘉诚", "李富贵"] print(lst) deleted = lst.pop() # 删除最后一个 print("被删除的", deleted) print(lst) el = lst.pop(2) # 删除2号元素 print(el) print(lst) lst.remove("李富贵") # 删除指定元素,删除不存在的元素会报错 print(lst) lst.clear() # 清空lst print(lst)
修改
索引切片修改
lst = ["李白", "王维", "罗贯中", "李清照", "苏宁"] lst[1] = "陈润" # 把1号元素修改成"陈润" print(lst) lst[1:5:2] = ["马化腾", "马云"] # 切片修改也ok,如果步长不是1,要注意,元素的个数 print(lst) lst[1:4] = ["周杰伦"] # 如果切片没有步长或者步长是1,则不用关心个数 print(lst)
查询,列表是一个可迭代对象,所以可以进行for循环
for el in lst: print(el)
其他操作
lst = ["陈润", "太白", "李白", "王维", "太阳"] c = lst.count("太白") print(c) lst = [1,11,22,2] lst.sort() # 排序,默认升序 print(lst) lst.sort(reverse = True) # 降序 print(lst) lst = ["月亮", "李白", "alex", "太白", "陈润"] print(lst) lst.reverse() print(lst)
列表的嵌套
采用降维操作,一层一层的查看
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)
元组和元组嵌套
元组:俗称不可变的列表,又被称为只读列表,元组也是python的基本数据类型之一,用小括号括起来,里面可以存放任何数据类型的数据,查询可以,循环也可以,切片也可以,但是布恩那个修改
tu = (1, "太白", "李白", "太黑", "太阳") print(tu) print(tu[0]) print(tu[1]) print(tu[2]) # for 遍历元组 for item in tu: print(item) # 尝试修改元组 # tu[1] = "c" # 报错'tuple' object does not support item assignment tu = (1,'哈哈', [], '呵呵') # tu[2] = ["sdksfj"] # 这么修改也不行 tu[2].append("chenrun") # 可以修改了. a = tu[1][0].replace("哈", "he") print(a) print(tu) # 不能修改元组的一级元素,可以修改元组内的列表或者字符串
关于不可变,注意:这里元组的不可变的意思是子元素不可变,而子元素内部的子元素是可以变的,这取决于子元素是否可变对象
元组中如果只有一个元素,一定要添加一个逗号,否则就不是元组
tu = (1,) print(type(tu))
元组也有count(),index(),len()等方法
range
range可以帮我们获取到一组数据,通过for循环能够获取到这些数据
for item in range(10): print(item) for el in range(1, 10, 2): print(el) for el in range(10, 1, -2): # 反着来,跟切片一样 print(el)
作业
利用for循环和range从100~10,倒序将所有的偶数添加到一个新的列表,然后对列表的元素经进行筛选,将能被4整除的数留下来.
new_lst = [] for item in range(100, 9, -1): if item%2 == 0: new_lst.append(item) print(new_lst) for el in new_lst: if el%4 == 0: pass else: new_lst.remove(el) print(new_lst)
# 10,利用for循环和range,将1 - 30 # 的数字一次添加到一个列表中,并循环这个列表,将能被3整除的数改成 *。 new_lst = [] for item in range(1, 31): new_lst.append(item) print(new_lst) index = 0 for el in new_lst: if el%3 == 0: new_lst[index] = "*" index += 1 print(new_lst)
开发敏感词过滤程序
li = ["苍老师", "东京热", "武藤兰", "波多野结衣"] comment = input("请输入您的评论>>") new_lst = [] for el in li: if el in comment: comment = ("*"*len(el)).join(comment.split(el)) new_lst.append(comment) print(new_lst)
循环打印每一级列表的内容
li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"] for item in li: if type(item) == list: for el in item: print(el) continue print(item)