python教程print_Python入门

昨天我们简单的接触了基础数据类型中的三个:int(整数),str(字符串),bool(布尔值).其中我们重点说的是str(字符串类型)的操作方法(一大波操作),那么今天让我们继续认识基础数据类型中的两个:列表(list)和元组(tuple),以及range的使用.

一.列表

1. 列表介绍

列表是python的基础数据类型之一 ,其他编程语言也有类似的数据类型. 比如JS中的数组, java中的数组等等.它是以[ ]括起来, 每个元素用逗号隔开而且可以存放各种数据类型:

lst = [1, '哈哈', "吼吼", [1,8,0,"百度"], ("我","叫", "元", "组"), "abc", {"我叫":"dict字典"},{"我叫集合","集合"}]

列表相比于字符串,不仅可以存放不同的数据类型, 而且可以存放大量的数据. 32位 python可以存放: 536870912个元素, 64位可以存放: 1152921504606846975个元素.而且列 表是有序的(按照你保存的顺序),有索引, 可以切片方便取值.

2. 列表的索引和切片

列表和字符串一样也拥有索引:

lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"]

print(lst[0]) # 获取第1个元素

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]) # 倒着带步长

3. 列表的增删改查

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

增:

lst = ["麻花藤", "林俊杰", "周润发", "周芷若"]

print(lst)

lst.append("wusir")

print(lst)

lst = []

while True:

content = input("请输入你要录入的员工信息, 输入Q退出:")

if content.upper() == 'Q':

break

lst.append(content)

print(lst)

lst = ["麻花藤", "张德忠", "孔德福"]

lst.insert(1, "刘德华") # 在1的位置插入刘德华. 原来的元素向后移动1位

print(lst)

# 迭代添加

lst = ["王志文", "张一山", "苦海无涯"]

lst.extend(["麻花藤", "麻花不疼"])

print(lst)

删:

lst = ["麻花藤", "王剑林", "李嘉诚", "王富贵"]

print(lst)

deleted = lst.pop() # 删除最后1个

print("被删除的", deleted)

print(lst)

el = lst.pop(2) # 删除2号元素

print(el)

print(lst)

lst.remove("麻花藤") # 删除指定元素

print(lst)

# lst.remove("哈哈") # 删除不存在的元素会报错

# # print(lst)

lst.clear() # 清空list

print(lst)

# 切片删除

del lst[1:3]

print(lst)

改:

# 修改

lst = ["太白", "太黑", "五色", "银王", "日天"]

lst[1] = "太污" # 把1号元素修改成太污

print(lst)

lst[1:4:3] = ["麻花藤", "哇靠"] # 切片修改也OK. 如果步长不是1, 要注意. 元素的个数

print(lst)

lst[1:4] = ["李嘉诚个龟儿子"] # 如果切片没有步长或者步长是1. 则不用关心个数

print(lst)

查:

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 = ["太白", "太黑", "五色", "银王", "日天", "太白"]

print(lst)

lst.reverse()

print(lst)

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

print(l)

4.列表的嵌套

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

st = [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)

二.元组和元组嵌套

元组: 俗称不可变的列表,又被成为只读列表. 元组也是python的基本数据类型之一, 用小括号括起来, 里面可以放任何数据类型的数据, 查询可以, 循环也可以, 切片也可以, 但就是不能改.

tu = (1, "太白", "李白", "太黑", "怎么黑")

print(tu)

print(tu[0])

print(tu[2])

print(tu[2:5]) # 切片之后还是元组

# for循环遍历元组

for el in tu:

print(el)

# 尝试修改元组

# tu[1] = "马虎疼" # 报错 'tuple' object does not support item assignment

tu = (1, "哈哈", [], "呵呵")

# tu[2] = ["fdsaf"] # 这么改不行

tu[2].append("麻花藤") # 可以改了. 没报错

tu[2].append("王剑林")

print(tu)

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

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

tu = (1,)

print(type(tu))

元组也有count(), index(), len()等方法, 可以自己测试一下.

三.range

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

for num in range(10):

print(num)

for num in range(1, 10, 2):

print(num)

for num in range(10, 1, -2): # 反着来, 和切片一样

print(num)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值