学习总结(Python 4)
1.列表(list)
列表是容器型数据类型;将[]作为容器的标志,里面多个元素用逗号隔开:[数据1, 数据2, 数据3,…]
列表是可变的(元素的个数和元素的值可变 - 支持增删改);列表是有序(顺序影响结果、支持下标操作)
列表的元素(保存在列表中的每个数据):可以是任何类型的数据
print([10, 20, 30] == [20, 10, 30]) # False
print('abc' == 'bac') # False
print({'a': 10, 'b': 20} == {'b': 20, 'a': 10}) # True
print({10, 20, 30} == {20, 10, 30}) # True
list1=[]
list2 = [10, 3.18, 'abc', True, None, [10, 20]]
list3 = [
['张三', 18, 90, '男'],
['小明', 20, 100, '男'],
['小花', 19, 78, '女']
]
1.)列表的增删改查
(1) 查- 获取列表中的元素
查单个 - 一次获取一个元素
语法:
列表[下标] - 获取列表中指定下标对应的元素
说明:
列表 - 具体的一个列表,或者是保存列表的变量
[] - 固定写法
下标 - 又叫索引,指的是元素在列表中的位置信息。
Python中有序序列中每个元素的下标有两个,一个是从前往后从0开始不断加1的下标值;另外一个是从后往前从-1开始不断减1的下标值。
注意:下标不能越界
格式例如:
nums=[10,20,30,40]
print(nums[1])
print(nums[0])
print(nums[1],nums[-1])
练习1:统计nums
中偶数的个数
nums = [46, 55, 80, 89, 71, 20]
count=0
for s in nums:
if s%2==0:
count+=1
print(count)
练习2:打印students中每个学生的名字
students = [
['张三', 18, 90, '男'],
['小明', 20, 100, '男'],
['小花', 19, 78, '女']
]
for x in students:
print(x[0])
(2). 增 - 在列表中添加元素
-
列表.append(元素) - 在指定列表的最后添加指定元素
格式例如:
names=['中国','美国','意大利','巴西']
names.append('卡塔尔世界杯')
print(names)
案例:提取nums
中所有的偶数, 得到新的列表
nums = [46, 55, 80, 89, 71, 20]
new_nums=[]
for s in nums:
if s%2==0:
new_nums.append(s)
print(new_nums)
-
列表.insert(下标, 元素) - 将指定元素插入到列表中指定下标对应的元素的前面
格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '赵云'] print(names) names.insert(-1, '后羿') print(names)
(3).删 - 删除元素
- del 列表[下标] - 删除列表中指定下标对应的元素
格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '后羿', '赵云']
print(names)
del names[1]
print(names)
-
列表.pop() - 取走列表最后一个元素并且返回
-
列表.pop(下标) - 取走列表中指定下标对应的元素并且返回
格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '甄姬', '后羿', '赵云'] print(names) result = names.pop() print(names, result) names = ['鲁班7号', '甄姬', '王昭君', '甄姬', '后羿', '赵云'] print(names) result = names.pop(2) print(names, result)
(4).改 - 修改某个元素的值
-
列表[下标] = 新值 - 将指定下标对应的元素修改成新的值
格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '甄姬', '后羿', '赵云'] print(names) names[-2] = '庄周' print(names)
2. )相关操作和相关函数
(1) 列表的加法和乘法运算
nums=[1,2,3]
new_nums=nums+[4,5]
print(new_nums) # [1,2,3,4,5]
new_nums = nums * 3 # nums + nums + nums
print(new_nums) # [1,2,3,4,5]
(2) in 和 not in
- 数据 in 列表 - 判断列表中是否存在指定数据对应的元素
- 数据 not in 列表 - 判断列表中是否不存在指定数据对应的元素
格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '甄姬', '后羿', '赵云']
print('赵云' in names) # True
print('陈咬金' in names) # False
(3).len
函数
-
len
(列表) - 获取列表的长度(获取列表中元素的个数)格式例如:
names = ['鲁班7号', '甄姬', '王昭君', '甄姬', '后羿', '赵云']
print(len(names)) # 6
nums = [10, 20, 30]
print(len(nums)) # 3
print(len('abcd')) # 3
(4).sum函数
-
sum(列表) - 求列表中所有元素的和(列表中的元素必须全部是数字)
格式例如:
nums = [10, 20, 30] print(sum(nums)) # 60 scores = [19, 1.2, 90, 78, 2.3, 100] print(sum(scores)) print(sum(range(101)))
(5).max ,mian
函数 -求最大值\最小值
-
max(列表)
-
min(列表)
举例:
scores = [19, 1.2, 90, 78, 2.3, 100, 55] print(max(scores)) # 100 print(min(scores)) # 1.2
(6) . sorted函数
-
变量 = sorted(列表) - 将列表中的元素从小到大排序(升序)产生一个新的列表保存到指定的变量中
-
变量 = sorted(列表, reverse=True) - 将列表中的元素从大到小排序(降序)产生一个新的列表保存到指定的变量中
举例如下:
scores = [19, 1.2, 90, 78, 2.3, 100, 55] new_scores = sorted(scores) print(new_scores) # [1.2, 2.3, 19, 55, 78, 90, 100] new_scores = sorted(scores, reverse=True) print(new_scores) # [100, 90, 78, 55, 19, 2.3, 1.2] print(scores) # [19, 1.2, 90, 78, 2.3, 100, 55]
2. 字典 (dict
)
-
字典是容器型数据类型; 将{}作为容器的标志,里面多个键值对用逗号隔开:{键1:值1, 键2:值2, 键3:值3,…}
-
字典是可变的(支持增删改);字典是无序的(顺序不影响结果;不支持下标操作)
-
字典的元素:
a.必须是键值对
b.键必须是不可变类型的数据(可以是数字、布尔、空值、字符串、元组,一般用字符串)
c.值可以是任何类型的数据 -
如果需要同时保存多个意义不同的数据的时候,字典比列表更好用
1.字典是无序的
print({'a': 10, 'b': 20} == {'b': 20, 'a': 10}) # True
2.查 — 获取值
- 字典[键] - 获取字典中指定键对应的值;如果键不存在会报错
- 字典.get(键) - 获取字典中指定键对应的值;如果键不存在不会报错并且返回None
- 字典.get(键, 默认值) - 获取字典中指定键对应的值;如果键不存在返回默认值
案例:班级信息包括:班级名称、位置、讲师、班主任、所有学生
class1 = {
'name': 'Python2206',
'address': '14教',
'lecturer': {
'name': '余婷',
'age': 18,
'qq': '726550822'
},
'class_teacher': {
'name': '吴静',
'age': 18,
'tel': '110'
},
'all_student': [
{'name': 'stu1', 'age': 20, 'gender': '男', 'tel': '11987223', 'linkman': {'name': '张三', 'tel': '81923'}},
{'name': 'stu2', 'age': 22, 'gender': '女', 'tel': '8293212', 'linkman': {'name': '小明', 'tel': '6666'}},
{'name': 'stu3', 'age': 25, 'gender': '女', 'tel': '727332', 'linkman': {'name': '李四', 'tel': '829333'}},
{'name': 'stu4', 'age': 19, 'gender': '男', 'tel': '563743', 'linkman': {'name': '老王', 'tel': '778822'}},
{'name': 'stu5', 'age': 23, 'gender': '男', 'tel': '0928322', 'linkman': {'name': '赵六', 'tel': '829101'}}
]
}
# 1)获取班级名称
print(class1['name'])
# 2)打印讲师的名字
# 方法1:
teacher = class1['lecturer']
print(teacher['name'])
# 方法2:
# print(class1['lecturer']['name'])
# 3)打印班主任的电话
class_teacher = class1['class_teacher']
print(class_teacher['tel'])
# 4)打印所有学生的名字
students = class1['all_student']
for stu in students:
print(stu['name'])
# 5)打印所有女同学的名字和电话
for stu in students:
if stu['gender'] == '女':
print(stu['name'], stu['tel'])
# 6)打印所有男生的联系人名字
for stu in students:
if stu['gender'] == '男':
linkman = stu['linkman']
print(linkman['name'])
3.字符串(str)
-
字符串是容器型数据类型;将单引号或者双引号作为容器的标志,引号中的每个符号就是字符串的元素(字符串的元素又叫字符)。
str1 = 'abc' print(str1) str2 = 'abc,123你好' print(str2) print(len(str2))
(1).转义字符 - 在特定的符号前加\来表示特殊意义或者特殊功能的符号
常见的转义字符:
\n - 表示换行
\t - 水平制表符(按一个tab键)
\' - 表示一个普通的单引号
\" - 表示一个普通的双引号
\\ - 表示一个普通的反斜杠
注意:计算字符串长度的时候,一个转义字符的长度是1
"""
举例如下:
str3 = '\tabc\n123'
print(str3)
print(len(str3))
str4 = "It's me"
print(str4)
str5 = 'It\'s me'
print(str5)
str6 = "I say:\"good good study, day day up!\""
print(str6)
str7 = 'abc\\n123'
print(str7)
path = 'C:\Admin\\test\\name\yuting\\a.txt'
print(path)
(2).字符串的相关操作
print('abc' + 'Hello') # 'abcHello'
print('abc' * 3) # 'abcabcabc'
print('a' in 'abcdef') # True
print('abc' in 'abcdef') # True
print('acb' in 'abcdef') # False
(3).格式字符串 - (f-string)
name = input('请输入学生的名字:')
age = int(input('请输入学生的年龄:'))
# message: 'xxx今年xx岁!'
# '小明'+'今年' -> '小明今年'
message = name + '今年' + str(age) + '岁!'
print(message)
message2 = f'{name*2}今年{age}岁!'
print(message2)
str1 = f'{10+20}abc'
print(str1)