day 5 note 数字和列表

day 5 note 数字和列表

1. 数字相关类型 (int, float, bool, complex)

1. int(整型) - 所有的整数对应的类型

1)表示: 数字直接写
2)转换:int(数据)
不是所有的数据都可以转换成整数,只有浮点数、布尔、部分字符串

*python 2. x 中整数有两种类型:int、long

浮点数转换成整数:直接去掉小数部分,保留整数部分

print(int(12.5))    # 12
print(int(1.9))     # 1
print(int(-1.9))    # -1

布尔转整数

print(int(True))    # 1
print(int(False))   # 0

字符串转整数 - 弃掉引号后本身就是一个整数的字符串才能转换成整型

print(int('a b c'))     # 报错

print(int('7823'))      # 7823

print(int('12.5'))    # 报错
2. float(浮点数) - 所有小数对应的类型

“”"
1)表示:直接表示, 支持科学计数法
2)转换:float(数据)
不是所有数据都可以转换成浮点型,只有整数、布尔和部分字符串可以转

print(float(10))    # 10.0
print(float(123))   # 123.0
print(float(True))  # 1.0

字符串转浮点型 - 去掉引号以后本身是有效数字的字符串都可以转换成浮点型

print(float('a b c'))    # 报错

print(float('123'))     # 123.0
print(float('0.12'))    # 0.12
print(float('3 e 4'))     # 30000.0
3. bool (布尔)

“”"
1)表示:直接写 - True、False
2)转换:bool(数据)
所有的数据都可以转换成布尔;零值和空值会转换成False, 其他的都是True
“”"

print(bool(-123))    # True
print(bool(0))      # False
print(bool(0.0))    # False
print(bool(''), bool(""))   # False False
print(bool([]))     # False

print(True + 1)    # 2
print(False*10)    # 0
4.*complex(复数) - 由实部和虚部组成的数

1)虚数单位是: j

2)虚部的1不能省

3)直接支持复数的运算

num 1 = 10+20 j
print(1 j**2)    # (-1+0 j)

num2 = 3 - 5 j
print(num 1 + num 2)    # 13+15 j
print(num 1 * num 2)    # (130+10 j)

2. 列表 ( list )

1.什么是列表(list)

*列表是容器型数据类型;*将[ ]作为容器的标志,里面多个元素用逗号隔开: [元素1, 元素2, 元素3,…]
元素:列表中的元素可以是任何类型的数据; 同一个列表中的元素的类型可以不同
特点:1.可变的(指的是元素的个数、元素的值和元素的顺序可变);2.有序的(元素有表示顺序的编号)
“”"

a = [ ]      a是一个空列表

b =     [ 100,  200,  True,  'a b c' ]
c =      [ 100, 200, ['a b c', 123] ]

元素的要求:任何类型的数据都可以作为列表的元素

d = [100,
     12.5,'a b c',[1, 2],(10, 20),{'name': '余婷', 'age': 18},{1, 5},lambda x: x**2]

print(type(d))    # <class 'list'>
print(b)

练习:定义变量保存一个班所有学生的成绩

方法一:

score 1 = 90 ,  score 2 = 78  score 3 = 56  , score 4 = 98,   score 5 = 99 ,   score 6 = 70

方法二:

scores = [90, 78, 56, 98, 99, 70]

------


3. 获取列表元素

1.获取单个元素

“”"
语法:列表[下标] - 获取指定下标对应的元素
**说明:**列表 - 任何结果是列表的表达式(具体的列表数据、保存列表数据的变量、…)
[ ] - 固定写法:
下标 - 又叫索引;它是元素在容器中的位置标志(元素在容器中的顺序值)
下标值的范围有两种:
1)从0开始不断加1的下标值, 其中0表示第一个、1表示第二个、…
2)从-1开始不断减1的下标值,其中-1表示倒数第一个、-2表示倒数第二个、…
注意:下标不能越界

list1 = [10, 20, 30, 'a b c']

print(list1[1], list1[-3])
print(list1[-1], list1[3])

print(list1[10])        # IndexError: list index out of range

print(l ist1[-5])        # IndexError: list index out of range

2. 获取部分元素(列表切片) - 同时获取列表中的多个元素

1)语法:列表[开始下标:结束下标:步长]
2)规则:
a.如果步长为正,表示从前往后取(从开始下标到结束下标), 开始下标对应的元素能取到,结束下标对应的元素取不到
b.如果步长为负,表示从后往前取(从开始下标到结束下标), 开始下标对应的元素能取到,结束下标对应的元素取不到
“”"

movies = ['阿甘正传', '肖生克的救赎', '当幸福来敲门', '霸王别姬', '花样年华', '人在囧途']
print(movies[1:5:1])    # ['肖生克的救赎', '当幸福来敲门', '霸王别姬', '花样年华']
print(movies[1:-1:1])   # ['肖生克的救赎', '当幸福来敲门', '霸王别姬', '花样年华']
print(movies[5:1:1])    # []
print(movies[5:1:-1])   # ['人在囧途', '花样年华', '霸王别姬', '当幸福来敲门']
print(movies[5:1:-2])   # ['人在囧途', '霸王别姬']
print(movies[1:-1:-2])  # []
print(movies[1:-2:1])   # ['肖生克的救赎', '当幸福来敲门', '霸王别姬']
print(movies[-1:-5:-2])     # ['人在囧途', '霸王别姬']
print(movies[-4:2:1])   # []

**1)省略步长: 列表[开始下标:结束下标]

**

省略步长就相当于步长为1: 列表[开始下标:结束下标] == 列表[开始下标:结束下标:1]

names = ['海贼王', '火影', '死神', '妖精的尾巴', '柯南', '犬夜叉', '进击的巨人', '一人之下']
print(names[1:-2])      # ['火影', '死神', '妖精的尾巴', '柯南', '犬夜叉']
print(names[-1:5])      # []

2)省略开始下标: 列表[:结束下标:步长] / 列表[:结束下标]

“”"
如果步长为正,省略开始下标表示从第一个元素开始往后取,取到结束下标对应的位置
如果步长为负,省略开始下标表示从最后一个元素开始往前取,取到结束下标对应的位置
“”"

print(names[:-2])       # ['海贼王', '火影', '死神', '妖精的尾巴', '柯南', '犬夜叉']
print(names[:5:2])      # ['海贼王', '死神', '柯南']
print(names[:-3:-1])    # ['一人之下', '进击的巨人']

3)省略结束下标: 列表[开始下标::步长] / 列表[开始下标:]

如果步长为正,省略结束下标,从开始下标取到最后一个元素
如果步长为负,省略结束下标,从开始下标取到第一个元素
“”"

names = ['海贼王', '火影', '死神', '妖精的尾巴', '柯南', '犬夜叉', '进击的巨人', '一人之下']
print(names[2:])        # ['死神', '妖精的尾巴', '柯南', '犬夜叉', '进击的巨人', '一人之下']

print(names[-3::-1])    # ['犬夜叉', '柯南', '妖精的尾巴', '死神', '火影', '海贼王']

print(names[4::-2])     # ['柯南', '死神', '海贼王']

print(names[-2::-3])    # ['进击的巨人', '妖精的尾巴', '海贼王']

4)同时省略开始下标和结束下标:列表[::步长] / 列表[:]

开始下标和结束下标都省,那么整个选择范围就是原列表

print(names[::-1])   # 倒序  ['一人之下', '进击的巨人', '犬夜叉', '柯南', '妖精的尾巴', '死神', '火影', '海贼王']
print(names[::-2])   # ['一人之下',  '犬夜叉', 妖精的尾巴', '火影']
print(names[:])      # ['海贼王', '火影', '死神', '妖精的尾巴', '柯南', '犬夜叉', '进击的巨人', '一人之下']

3.遍历(一个一个的把所有元素取出来)

方法一: 直接遍历出列表中的元素
for 元素 in 列表:
循环体
(变量取到的就是列表中的元素)

方法二:通过遍历获取所有元素的下标来遍历元素

for 下标 in range(列表长度):
列表[下标]

方法三(了解)

for 下标, 元素 in enumerate(列表):
循环体


games = [‘斗地主’, ‘欢乐麻将’, ‘开心消消乐’, ‘三国杀’, ‘王者荣耀’, ‘英雄联盟’]

1)直接获取元素(掌握)

for item in games:
    print('item:', item)

2)直接获取下标,通过下标获取元素(掌握)

len(列表)  - 获取列表中元素的个数

for index in range(len(games)):
    print('下标:', index, '元素:', games[index])

3)同时获取下标和元素(了解)

for index, item in enumerate(games):
    print('index:', index, 'item:', item)

enumerate(games)  -> [(0, '斗地主'), (1, '欢乐麻将'),... ]

for x in [12, 34, 45]:

print(x)

for x, y in [(1, 2), [10, 20], 'ab']:

print('x y:', x, y)

for x,y,z in [(1, 2, 3), (10, 20, 30), 'a b c', ['name', 'age', 'sex']]:

print('x y z:', x, y, z)

scores = [10, 78, 90, 8, 77, 65, 100]   ->  ['不及格', 78, 90, '不及格', 77, 65, 100]

练习:

1)用一个列表保存一个班10个学生的成绩

scores = [45, 89, 78, 90, 65, 70, 23, 57, 100, 66]

2)计算10个学生的总成绩

3)计算10个学生的平均成绩

length = len(scores)
sum 1 = 0
for item in scores:
    sum 1 += item
print('总成绩:', sum 1, '平均成绩:', sum 1 / length)

4)统计不及格学生的人数

count = 0
for item in scores:
    if item < 60:
        count += 1
print('不及格人数:', count)

5)获取10个学生成绩最高成绩的值

max 1 = scores[0]     # 假设第一个元素的值最大
for item in scores[1:]:
    if item > max 1:
        max 1 = item
print('最高分:', max 1)

4. 元素的增删改

1. 增 - 添加元素

1) 列表.append(元素) - 在列表的最后添加指定元素

names = ['余婷', '张瑞燕', '迪丽热巴', '古力娜扎']
print(names)    # ['余婷', '张瑞燕', '迪丽热巴', '古力娜扎']

names.append('蔡徐坤')
print(names)    # ['余婷', '张瑞燕', '迪丽热巴', '古力娜扎', '蔡徐坤']

2) 列表.insert(下标, 元素) - 在指定下标对应的元素前插入指定元素

names.insert(2, ' 杨幂 ')
print(names)            # ['余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '蔡徐坤']

names.insert(0, '胡歌')   # ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '蔡徐坤']
print(names)

names.insert(-1, '彭于晏')
print(names)        # ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '彭于晏', '蔡徐坤']


2. 删 - 删除元素

1) del 列表[下标]

names = ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '彭于晏', '蔡徐坤']
**del names[3]**
print(names)        # ['胡歌', '余婷', '张瑞燕', '迪丽热巴', '古力娜扎', '彭于晏', '蔡徐坤']

**del names[-1]**
print(names)      # ['胡歌', '余婷', '张瑞燕', '迪丽热巴', '古力娜扎', '彭于晏']

del names[7]      # Index Error: list assignment index out of range

**del names**         # 删除整个列表

2) 列表.remove(元素) - 删除列表中指定的元素

a.如果元素不存在会报错

b.如果元素有多个,只删第一个

names = ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '彭于晏', '迪丽热巴', '蔡徐坤', '迪丽热巴']
names.remove('杨幂')
print(names)    # ['胡歌', '余婷', '张瑞燕', '迪丽热巴', '古力娜扎', '彭于晏', '迪丽热巴', '蔡徐坤', '迪丽热巴']

names.remove('朱茵')   # ValueError: list.remove(x): x not in list

names.remove('迪丽热巴')
print(names)

3) 列表.pop( ) - 取出列表中最后一个元素, 并返回

列表.pop(下标) - 取出列表中指定下标对应的元素, 并返回(下标不能越界)

names = ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '彭于晏', '蔡徐坤']
del_name = names.pop()
print(names, del_name)    # ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '古力娜扎', '彭于晏'] 蔡徐坤

del_name = names.pop(-2)
print(names, del_name)    # ['胡歌', '余婷', '张瑞燕', '杨幂', '迪丽热巴', '彭于晏'] 古力娜扎

作业1:用一个列表保存学生的分数,删除列表中所有低于60分的成绩

scores = [90, 45, 52, 10, 89, 67, 55, 32, 69, 100]

最终结果: [90, 89, 67, 69, 100]
3. 改 - 修改元素的值

语法:列表[下标] = 新元素 - 修改指定下标对应的元素(下标不能越界)

teleplays = ['琅琊榜', '亮剑', '庆余年', '爱情公寓', '人民的名义', '甄嬛传', '请回答1988']
teleplays[3] = '爱情公寓4'
print(teleplays)

练习:scores = [10, 78, 90, 8, 77, 65, 100] -> [‘不及格’, 78, 90, ‘不及格’, 77, 65, 100]

方法一

scores = [10, 78, 90, 8, 77, 65, 100]
for index, item in enumerate(scores):
    if item < 60:
        scores[index] = '不及格'

print(scores)   # ['不及格', 78, 90, '不及格', 77, 65, 100]

#方法二:

scores = [10, 78, 90, 8, 77, 65, 100]
new_scores = [ ]
for item in scores:
    if item < 60:
        new_scores.append('不及格')
    else:
        new_scores.append(item)
print(new_scores)    # ['不及格', 78, 90, '不及格', 77, 65, 100] 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值