day8课堂总结

01-recode

1.列表(list) - 可变,有序 - []

a.获取元素 - 通过下标获取元素

b.增删改
增 - append,insert,(extend)
删 - remove,del,pop,clear
改 - 列表[下标] = 新值

c.相关运算: +, *, in/not in, len(), list(), max(), min()

2.元祖(tuple) - 不可变,有序 - ()

a.获取元素 - 通过下标获取元素
变量1, 变量2 = 元素1, 元素2
变量1, *变量2 = 元素1, 元素2, 元素3, 元素4
(元素,)

c.相关运算: +, *, in/not in, len(), tuple(), max(), min()

3.字典(dict) - 可变, 无序 - {}

a.获取元素 - 通过键获取元素

b.增删改
增 - 字典[key] = 值; 字典1.update(字典2)
删 - del 字典[key]; 字典.pop(key); clear
改 - 字典[key] = 值;字典1.update(字典2)

c.相关运算:in/not in, len(), dict(), max(), min()
max和min - 取的是字典的key的最大值和最小值
print(len({'a': 10, 'b': 20}))
dict1 = dict([(1, [1, 2]), ['a', 'b'], ('aaa', 100)])
print(dict1)

dict2 = {'a': 10, 'd': 20, 'c': 30}
print(max(dict2))
print(min(dict2))



02-字典相关方法

1.clear

字典.clear() - 清空字典(删除字典中所有的键值对)
dict1 = {'a': 100, 'b': 200}
dict1.clear()
print(dict1)

2.copy

字典.copy() - 复制字典中所有的键值对,产生一个新的字典
dict1 = {'a': 100, 'b': 200}
dict2 = dict1.copy()   # 这儿会产生新的地址
print(dict2)
dict1['a'] = 1
print(dict2)

3.fromkeys

dict.fromkeys(序列, 值) - 以序列中的元素作为key,值作为所有key对应的默认值,创建一个字典
dict3 = dict.fromkeys('xyzp', 100)
print(dict3)   # {'x': 100, 'y': 100, 'z': 100, 'p': 100}
dict3 = dict.fromkeys(['name', 'age', 'height'], 100)
print(dict3)    # {'name': 100, 'age': 100, 'height': 100}

4.get

字典.get(key) - 获取key对应的值,如果key不存在,返回None
字典.get(key,值) - 获取key对应的值,如果key不存在,返回指定的值
dict3 = {'name': 100, 'age': 100, 'height': 100}
print(dict3.get('name'))   # 100
print(dict3.get('name', '不存在'))   # 100
print(dict3.get('name1'))       # None
print(dict3.get('name1', '不存在'))    # 不存在

5.keys, values, items

字典.keys() - 获取字典所有的key(返回一个序列,序列中的元素就是字典的key)
字典.values() - 获取字典所有的值(返回一个序列,序列中的元素就是字典的value)
字典.items() - 获取字典所有的键值对(返回一个序列,序列中的元素是元祖,元祖中元素有两个分别是key和value)
dict4 = {'x': 23, 'y': 89, 'z': 234, 'p': 100}

# 获取所有的key

keys = dict4.keys()
print(keys, type(keys))  # 返回值是序列,但是不是列表
# print(keys[0])
for item in keys:
    print(item)

# 获取所有的值
print(dict4.values())

print(dict4.items())  # dict_items([('x', 23), ('y', 89), ('z', 234), ('p', 100)])

6.setdefault

字典.setdefault(key, value) - 给字典添加键值对(注意:如果key本来就存在,
不会修改这个key的值 - 对原字典没有影响)
dict4 = {'x': 23, 'y': 89, 'z': 234, 'p': 100}
dict4.setdefault('xx', 'abc')
print(dict4)    # {'x': 23, 'y': 89, 'z': 234, 'p': 100, 'xx': 'abc'}

dict4 = {'x': 23, 'y': 89, 'z': 234, 'p': 100}
dict4.setdefault('x', 'abc')
print(dict4)  # {'x': 23, 'y': 89, 'z': 234, 'p': 100}



03-集合基本操作

1.什么是集合(set)

a.集合是python内置的一个容器类的数据类型,是可变、无序的

b.字面量 - 使用{}括起来,里面有多个元素,多个元素之间用逗号隔开
{1, 2, 3}

c.元素 - 不是键值对; 必须是不可变的,而是还是唯一的
set1 = {1, 'hello', True, (1, 3)}
# set2 = {1, 'hello', True, [1, 3]}  # TypeError, 集合中的元素不可变

set3 = {1, 'hello', True, (1, 3), 1}
print(set3)

set4 = {}   # {} - 是空的字典,不是空的集合
print(type(set4))

set4 = set()  # 创建一个空的集合
print(type(set4), set4)

2.集合的增删改查

a.查(获取集合元素)
不能直接获取集合中单独的某个元素,只能遍历

set3 = set('hello,world')
print(set3)
for item in set3:
    print(item)

b.增(添加元素)
集合.add(元素) - 将指定的元素添加到集合中
集合.update(序列) - 将序列中的元素添加到集合

set3.add(100)
print(set3)

set3.update([10, 20])
print(set3)

c.删(删除元素)
集合.remove(元素) - 删除集合中指定的元素

set3 = {100, 'w', 'h', 'e', ',', 'd', 'o', 'l', 'r'}
set3.remove(100)
print(set3)

d.改 - 集合不能修改元素的值

# in/not in, max, min, len, set

set(序列) - 将序列转换成集合

print(2 in {1, 2, 3})   # True
print({1, 2} in {1, 2, 3})   # False



04-数学集合运算

python中的集合支持数学相关的集合运算

1.包含关系

集合1 >= 集合2  判断集合1中是否包含集合2(判断集合2是否是集合1的子集)
集合1 <= 集合2  判断集合2中是否包含集合1(判断集合1是否是集合2的子集)
print({1, 2, 3} >= {1, 10})  # False
print({1, 2, 3} >= {2, 3})  # True
print({1, 2, 3} <= {1, 2, 3, 9, 10})  # True

2.求并集

集合1 | 集合2  - 将两个集合中的元素合并在一起产生一个新的集合
set1 = {1, 2, 3, 4, 5, 6}
set2 = {4, 5, 6, 7, 8}
print(set1 | set2)  # {1, 2, 3, 4, 5, 6, 7, 8}

2.求交集

集合1 & 集合2 - 使用两个集合中公共的元素,创建一个新的集合
print(set1 & set2)

3.求差集

集合1 - 集合2 - 使用集合1中除了集合2的部分以外的元素,创建一个新的集合
print(set1 - set2)

4.求补集

集合1 ^ 集合2 - 使用两个集合中除了公共部分以外的元素,创建一个新的集合
print(set1 ^ set2)

# list1 = [1, 34, 556, 78, 23, 2, 1]
# set1 = set(list1)
# print(set1)
# list1 = list(set1)
# list1.sort()
# print(list1)



08-认识函数

1.函数的定义

a.定义
函数就是对实现某一特定功能的代码段的封装

b.分类
函数可以分为内置函数和自定义函数
内置函数:python已经声明好了,程序员直接调用的函数。print函数, input函数,max等
        相当于已经造好的机器,程序员只需要知道机器的功能和使用方法
自定义函数: 程序员自己声明,自己实现功能的函数。可以提供给别人用,也可以自己用。
        相当于自己设置和创建机器。

2.函数的声明

a.语法:
def 函数名(形参列表):
    函数说明文档
    函数体
    
b.说明:
def - python中声明函数的关键字
函数名 - 自己命名;要求:标识符, 不能是关键字
        PEP8,名字中的字母小写,多个单词之间用下划线隔开
        见名知义(看到函数名,大概知道函数的功能)
() - 固定写法
形参列表 - 形参名1,形参名2... (可以有一个参数,也可以有多个参数,也可以没有参数)
          形参的作用:从函数的外部,向函数内部传递数据
: - 固定写法
函数说明文档 - 用来对函数的功能进行说明的注释。这个注释需要使用是三个双引号引起来
函数体 - 实现函数功能的代码段

c.初学者函数声明的步骤
第一步:确定函数的功能
第二步:根据函数的功能,确定函数名
第三步:确定参数,看实现函数的功能,需不需要额外的数据。需要几个数据,就需要几个参数
第四步:实现函数的功能
第五步:确定返回值

声明一个函数,求两个数的和,并且打印出来

def my_sum(num1, num2):
    print(num1 + num2)

声明一个函数,打印10个'*'

def print_star():
    print('*'*10)

声明一个函数,求1+2+3+...+n

def my_sum2(n):
    sum1 = 0
    for x in range(1, n+1):
        sum1 += x
    print(sum1)

2.函数的调用

(重点)函数在声明的时候不会执行函数体,只有在调用的时候才会执行

a.语法:
函数名(实参列表)

b.说明:
函数名 - 必须是已经声明过的函数
() - 固定写法
实参列表 - 实参就是给形参赋值(需要传递给函数内部的数据)
         目前,形参有多个少,实参就需要多少个
my_sum(10, 20)
my_sum(100, 200)

print_star()

my_sum2(100)

你可能感兴趣的:(day8课堂总结)