Python学习笔记

第六章

P62:数据容器

  1. 一种可以存储多个元素的python数据类型,存储的每一份数据称为元素;
  2. 分为5类:list(列表)、tuple(元组)、str(字符串)、set(集合)、dict(字典)

P63:列表(list)

list(列表)用[](中括号)作为标识,元素之间用,号隔开

# 字面量
[元素1, 元素2, 元素3, ...]
# 定义变量
变量名称 = [元素1, 元素2, 元素3, ...]
# 定义空列表
变量名称 = []
变量名称 = list()

P64:下标索引

  1. 列表的每一个元素都有相应的编号,称为下标索引;
  2. 从前往后,编号从0开始递增;从后往前,编号从-1开始递减
# 语法:列表[下标索引]

my_list = ["tom", "tony", "lily"]
print(my_list[0]) # 输出结果是:tom
print(my_list[-1]) # 输出结果是:lily

P65:列表的操作方法

# 定义列表
my_list = ["itheima", "python", "pycharm", "tony", "li", "son"]
# 1 查找下标 查找元素tony在列表内的下标索引(需要变量接收)
index = my_list.index("tony")
# 2 修改元素 修改下标索引为0的itheima的值为learn
my_list[0] = "learn"
# 3 插入元素 在下标索引为1的地方,插入新元素berry
my_list.insert(1, "berry")
# 4 追加元素 在尾部追加单个新元素sunny
my_list.append("sunny")
# 5 追加元素 在尾部追加多个新元素1, 2, 3
my_list.extend([1, 2, 3])
# 6.1 删除下标为1的元素python
del my_list[1]
# 6.2 删除下标为3的元素tony,可以获取到它的值(需要变量接收)
element = my_list.pop(3)
# 7 删除列表中指定的元素li
my_list.remove("li")
# 8 清空列表
my_list.clear()
# 9 统计元素python在列表中的数量(需要变量接收)
count = my_list.count("python")
# 10 统计列表中元素的数量(需要变量接收)
count = len(my_list)
练习题
# 有一个列表,记录学生的年龄,内容是:[21, 25, 21, 23, 22, 26]

# 通过列表功能(方法),进行以下操作:
# 1 定义这个列表,并用变量接收
my_list = [21, 25, 21, 23, 22, 26]
# 2 追加一个数字31,到列表的尾部
my_list.append(31)
# 3 追加一个新列表[28, 33, 27]到列表尾部
my_list.extend([28, 33, 27])
# 4 取出第一个元素
num1 = my_list[0]
# 5 取出最后一个元素
num2 = my_list[-1]
# 6 查找元素25的下标索引
index = my_list.index(25)
print(index)

P67:列表(list)的循环遍历

  1. 将容器内的元素依次取出并处理,称为遍历,也叫迭代;
  2. 可以使用 while 或者 for 进行循环处理
# while循环
def list_while_func():
    my_list = ["lily", "lucy", "lilei", "jim"]
    index = 0
    while index < len(my_list):
        element = my_list[index]
        print(f"列表的元素是:{element}")
        index += 1
list_while_func()

# for循环
def list_for_func():
    my_list = ["lily", "lucy", "lilei", "jim"]
# 语法:for 临时变量 in 数据容器
    for element in my_list:
        print(f"列表的元素是:{element}")
list_for_func()
练习题
# 定义一个列表,内容是[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
#遍历列表,取出列表内的偶数,并存入一个新的列表对象中

# 定义原始列表
original_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

# 使用while循环取出偶数
# 定义while循环偶数列表list
even_numbers_while = []
index = 0
while index < len(original_list):
    if original_list[index] % 2 == 0:
        even_numbers_while.append(original_list[index])
    index += 1

# 使用for循环取出偶数
# 定义for循环偶数列表list
even_numbers_for = []
for number in original_list:
    if number % 2 == 0:
        even_numbers_for.append(number)

# 打印结果
print("Even numbers using while loop:", even_numbers_while)
print("Even numbers using for loop:", even_numbers_for)

P68:元组(tuple)

  1. 元组使用()作为标识,元素之间用 , 隔开;
  2. 不可以修改内容(可以修改内部list的内部元素)
# 定义元组字面量
(元素1, 元素2, ...元素)
# 定义元组变量
变量名称 = (元素1, 元素2, ...元素)
# 定义空元组
变量名称 = ()
变量名称 = tuple()
# 定义元组
tuple_list = ("张三", "李四", "王五", "赵六")
# 查找下标索引
index = tuple_list.index("李四")
# 统计元素在元组中的数量
count = tuple_list.count("张三")
# 统计元组中元素的数量
count = len(tuple_list)

P69:字符串(str)

  1. 字符串可以看做字符的容器,支持下标索引
  2. 只可以存储字符串,允许重复字符串存在,不支持修改

# 1. 查找下标索引
my_str = "今天是个好天气"
value = my_str.index("好")
print(value)
# 输出结果:
4

# 2. 字符串的替换
# 语法:字符串.replace(元素1, 元素2)
# 功能:将字符串内全部的元素1替换为元素2
# 注意:不会修改字符串,而是得到一个新的字符串
my_str = "今天是个好天气"
new_my_str = my_str.replace("好", "不错的")
print(new_my_str)
# 输出结果:
"今天是个不错的天气"

# 3. 字符串的分割
# 语法:字符串.split(分隔符元素)
# 功能:按照指定的分隔符元素,将字符串划分为多个元素,并存入列表对象中
# 注意:不会修改字符串,而是得到一个list(列表)对象
my_str = "Ross, Julie, Gloria, Carol, Linda"
my_str_list = my_str.split(",")
print(my_str_list)
# 输出结果:
['Ross', ' Julie', ' Gloria', ' Carol', ' Linda']

# 4.1 字符串的规整操作(去除首尾空格)
# 语法:字符串.strip()
my_str = " 今天是星期二 "
new_my_str = my_str.strip() #不传入参数,则去除首尾空格
print(new_my_str)
# 输出结果:
"今天是星期二"

# 4.2 字符串的规整操作(去除首尾指定元素)
# 语法:字符串.strip(元素)
my_str = "今天是星期二"
new_my_str = my_str.strip("二") #切记:是首尾的元素,其他位置不行
print(new_my_str)
# 输出结果:
"今天是星期"

# 5. 统计某个元素的数量
my_str = "Ros, Julie, Gloria, Carol, Linda"
count = my_str.count("a")
print(count)
#输出结果:
3

# 6. 统计字符数的长度
my_str = "Ros, Julie, Gloria, Carol, Linda"
num = len(my_str)
print(num)
# 输出结果:
32

P71:序列切片

  1. 序列是指:内容连续,有序,支持下标索引的一类数据容器
  2. 列表,元组,字符串,都可以视为序列
# 切片语法:序列[起始下标:结束下标:步长]
# 表示序列中,从指定位置开始,到指定位置结束,依次取出元素,得到一个新序列
# 起始下标留空,视为从头开始;
# 如果指定了结束下标,则不包含对应元素;留空视为到结尾结束,包含全部元素
# 步长表示间隔(默认为1,可以不写):
# 1表示一个一个取出元素;2表示间隔一个取出元素;负数表示反向取出(下标也要反向标记)

P73:集合(set)

  1. 集合(set)是一个无序的、不包含重复元素的数据结构(自带去重,不支持下标索引)
  2. 支持for循环
# 定义集合字面量
{元素1, 元素2, 元素3, ...}
# 定义集合变量
变量名称 = {元素1, 元素2, 元素3, ...}
# 定义空集合
变量名称 = set()
# 1.添加新元素
# 语法:集合.add(元素)
my_set = {"龙凤呈祥", "百年好合", "马到成功", "龙马精神", "心心相印"}
my_set.add("大吉大利")
print(my_set)
# 输出结果:
{'心心相印', '百年好合', '龙凤呈祥', '龙马精神', '马到成功', '大吉大利'}

# 2.移除元素
# 语法:集合.remove(元素)
my_set = {"龙凤呈祥", "百年好合", "马到成功", "龙马精神", "心心相印"}
my_set.remove("马到成功")
print(my_set)
# 输出结果:
{'龙马精神', '龙凤呈祥', '百年好合', '心心相印'}

# 3.随机取出一个元素,原集合被修改
# 语法:my_set.pop()
my_set = {"龙凤呈祥", "百年好合", "马到成功", "龙马精神", "心心相印"}
element = my_set.pop()
print(element)
# 输出结果:
龙凤呈祥

# 4.清空集合
# 语法:集合.clear()
my_set.clear()
print(my_set)
# 输出结果:
set()

# 5.取出2个集合的差集
# 语法:集合1.difference(集合2)
# 功能:取出集合1有,集合2没有的
# 结果:得到一个新集合,原集合不变
set1 = {"Joan", "Niki", "Betty"}
set2 = {"Niki", "Betty", "Linda"}
set3 = set1.difference(set2)
print(set3)
# 输出结果:
{'Joan'}

# 6.删除2个集合的差集
# 语法:集合1.difference_update(集合2)
# 功能:在集合1里面,删除与集合2相同的元素
# 结果:集合1被修改,集合2不变
set1 = {"Joan", "Niki", "Betty"}
set2 = {"Niki", "Betty", "Linda"}
set1.difference_update(set2)
print(set1)
# 输出结果:
{'Joan'}

# 7.合并2个集合
# 语法 集合1.union(集合2)
# 功能:将集合1和集合2组成新合集
# 结果:得到新合集,原合集不变
set1 = {1, 2, 3, 4}
set2 = {4, 6, 8, 4}
set3 = set1.union(set2)
print(set3)
# 输出结果:
{1, 2, 3, 4, 6, 8} # 合集有去重复功能,所以不会有相同元素

# 8.统计集合中元素的数量
# 语法:len(集合)
set1 = {1, 2, 3, 4, 5, 6, 4}
num = len(set1)
print(num)
# 输出结果:
6 # 集合去重复,所以元素4只统计一次

# 9.集合的遍历
# 集合是无序的不重复元素序列,所以不支持下标索引,只能用for循环
set = {"Kevin", "Louis", "John", "George", "Henry"}
for element in set:
    print(element)
# 输出结果:
Louis
Henry
John
Kevin
George

P75:字典(dict)

# 字典 = dictionary 键值对 = key-value pairs

# 定义字典字面量
{key: value, key: value, key: value}
# 定义字典变量
my_dict = {key: value, key: value, key: value}
# 定义空字典
my_dict = {}
my_dict = dict()
# 1.获取字典中的值:
# 语法:字典[key]
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
value = my_dict["Joan"]
print(value)
# 输出结果:
75

# 2.添加字典中的键值对:
# 语法:字典[key] = value
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
my_dict["lily"] = 69
print(my_dict)
# 输出结果:
{'Malcolm': 65, 'Joan': 75, 'Niki': 81, 'Betty': 72, 'lily': 69}

# 3.修改字典中的键值对:
# 语法:字典[key] = value
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
my_dict["Niki"] = 69
print(my_dict)
# 输出结果:
{'Malcolm': 65, 'Joan': 75, 'Niki': 69, 'Betty': 72}
# 2和3语法相同,如果键(key)存在,则是修改;不存在,则是添加

# 4.1删除字典中的键值对:
# 语法:del 字典[key]
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
del my_dict["Betty"] 
print(my_dict)
# 输出结果:
{'Malcolm': 65, 'Joan': 75, 'Niki': 81}

# 4.2删除字典中的键值对,并返回值
# 语法:my_dict.pop(key)
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
score = my_dict.pop("Joan")
print(score)
print(my_dict)
# 输出结果:
75
{'Malcolm': 65, 'Niki': 81, 'Betty': 72}

# 5.清空字典
# 语法:字典.clear()
my_dict = {"Malcolm": 65, "Joan": 75, "Niki": 81, "Betty": 72}
my_dict.clear()
print(my_dict)
# 输出结果:
{}

# 6.1获取字典中的所有键:
my_dict = {"Malcolm":65, "Joan": 75, "Niki": 81, "Betty": 72}
keys = my_dict.keys()  # 返回字典中所有键的视图
print(keys)
# 输出结果:
dict_keys(['Malcolm', 'Joan', 'Niki', 'Betty'])

# 6.2获取字典中的所有值:
my_dict = {"Malcolm":65, "Joan": 75, "Niki": 81, "Betty": 72}
values = my_dict.values()  # 返回字典中所有值的视图
print(values)
# 输出结果:
dict_values([65, 75, 81, 72])

# 6.3获取字典中的所有键值对:
my_dict = {"Malcolm":65, "Joan": 75, "Niki": 81, "Betty": 72}
items = my_dict.items()  # 返回字典中所有键值对的视图
print(items)
# 输出结果:
dict_items([('Malcolm', 65), ('Joan', 75), ('Niki', 81), ('Betty', 72)])

# 7.1字典的遍历: 遍历键 
for key in my_dict:  
    print(key)  
  
# 7.2字典的遍历:遍历值  
for value in my_dict.values():  
    print(value)  
  
# 7.3字典的遍历:遍历键值对  
for key, value in my_dict.items():  
    print(key, value)

# 8.获取字典的长度:
# 语法:len(字典)
my_dict = {"Malcolm":65, "Joan": 75, "Niki": 81, "Betty": 72}
num = len(my_dict)
print(num)
# 输出结果:
4

P78:5类数据容器的对比

 P79:数据容器的通用操作

ASCII码表

 第七章

P81:函数的多返回值

def get_user_info():
    # 假设这个函数获取用户信息并返回一个包含用户名、年龄和城市的元组
    return 'Alice', 30, 'New York'

# 使用多变量赋值来接收函数返回的多个值
name, age, city = get_user_info()

print("Name:", name)
print("Age:", age)
print("City:", city)
# 输出结果:
Name: Alice
Age: 30
City: New York

P82:函数的传参方式:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值