Day6-python字典和集合

一、字典的基本操作

预:什么时候使用

如果需要同时保存多个数据 -> 序列(容器型数据类型)
如果要保存的多个数据是相同意义的数据(数据之间不需要区分) -> 列表
如果要保存的多个数据的意义不同(数据之间需要分区) -> 字典

student = ['余婷', 18, '女', 155, 50, 89]
student1 = ['张三', 50, '男', 170, 50, 45]
print(student[1])
print(student1[-1])

student2 = {'name': '余婷', '年龄': 18, '性别': '女', '身高': 155, '体重': 50, '成绩': 89}
print(student2['年龄'])
print(student2['成绩'])

1.什么是字典(dict)

a.什么是字典

字典是容器型数据类型, 将{}作为容器的标志,里面多个元素用逗号隔开,但是字典中的元素是键值对: {键1:值1, 键2:值2,...}
可变的(支持增删改), 无序(不支持下标操作)

b.键值对

字典中的所有元素都必须是键值对, 键和值必须成对出现; 字典存数据存的是值,键是用来区分和说明不同的值的
- 任意不可变的数据都可以作为键, 实际开发的时候一般将字符串做为key;键是唯一的
- 任何类型的数据都可以作为字典的value

dict1 = {'abc': 19, 'a': True, 'b': [1, 2], 'c': {'name': '小明'}}
print(dict1)

键是不可变

dict2 = {10: 100, 'a': 200, (1, 2): 300}
# dict3 = {10: 100, 'a': 200, ['a': 10]: 300}     # TypeError: unhashable type: 'list'
# key是唯一的
dict4 = {'a': 10, 'a': 100, 'b': 20}
print(dict4)    # {'a': 100, 'b': 20}

2.字典的增删改查

1)查 - 获取字典的值

a.获取单个值

字典[key] - 获取字典中指定key对应的值, 如果key不存在会报错
字典.get(key) - 获取字典中指定key对应的值, 如果key不存在不会报错,并且返回None
字典.get(key, 默认值) - 获取字典中指定key对应的值, 如果key不存在不会报错, 并且返回指定的默认值

person = {'name': '小明', 'age': 20, 'tel': '1530002273'}
print(person['tel'])
# print(person['height'])   # KeyError: 'height'

print(person.get('age'))
print(person.get('height'))       # None
print(person.get('height', 0))    # 0

b.遍历

for key in 字典:
    循环体

①推荐使用这种方式遍历

for x in person:
print('x:', x, person[x])

②其他的遍历方式(不要写这样的代码)

for key, value in person.items():
print(key, value)
print(person.items())

# list1 = []
# for key in person:
#     tuple1 = (key, person[key])
#     list1.append(tuple1)
# print(list1)
# for key, value in list1:
#     print(key, value)

3.增/改

字典[key] = 值 - 当key存在的时候,修改字典指定key对应的值;当key不存在的时候,添加'key:值'的键值对

person = {'name': '小明', 'age': 20, 'tel': '1530002273'}
person['name'] = '小花'
print(person)
person['score'] = 90
print(person)

4.删 - 删除键值对

1) del 字典[key] - 删除字典中指定key对应的键值对
2) 字典.pop(key) - 取出字典中指定key对应的值(key对应的键值对会从字典中消失)
person = {'name': '小花', 'age': 20, 'tel': '1530002273', 'score': 90}
del person['age']
print(person)

name = person.pop('name')
print(person, name)

练习: 保存一个班所有的学生的信息(姓名、学号、年龄、成绩、电话; 假设一般5个人)

all_student = [
    {'name': '小明', 'age': 28, 'score': 90, 'tel': '1828333333'},
    {'name': '小红', 'age': 16, 'score': 78, 'tel': '16253723283'},
    {'name': 'Tom', 'age': 21, 'score': 23, 'tel': '12623378293'},
    {'name': 'Bom', 'age': 17, 'score': 98, 'tel': '13572378237'},
    {'name': '大黄', 'age': 30, 'score': 76, 'tel': '18923672368'}
]

1)统计以上学生中不及格学生的人数

count = 0
for student in all_student:
    if student['score'] < 60:
        count += 1
print('不及格学生的人数:', count)

2)将打印所有未成年人学生的姓名

print('未成年学生:')
for student in all_student:
    if student['age'] < 18:
        print(student['name'])

3)将年龄为25岁以上的学生的电话号码设置为'保密'

for student in all_student:
    if student['age'] > 25:
        student['tel'] = '保密'
print(all_student)

二、字典相关操作

1.运算符: ==, !=, is

不支持+, *, <, <=, >, >=

dict1 = {'a': 1, 'b': 2}
dict2 = {'b': 2, 'a': 1}
print(dict1 == dict2)    # True

# print(dict1 + dict2)    # TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
# print(dict2 > dict1)    # TypeError: '>' not supported between instances of 'dict' and 'dict'

2.in / not in

key in 字典 / key not in 字典 - 判断key是否存在/不存在

dog = {'name': '旺财', 'age': 3, 'kind': '中华田园犬'}
print('name' in dog)    # True
print('旺财' in dog)     # False

3.len, dict

len(字典) - 字典的长度(字典键值对的个数)
dict(数据) - 将指定的数据转换成字典;

数据的要求:

1). 数据本身是序列
2). 序列中的元素也是序列
3). 小序列中的元素有且只有两个,第一个元素不可变

dict3 = dict([[1, 2], ('a', 'b'), ('name', '小明'), ['age', 18], 'he'])
print(dict3)

字典转列表 - 将字典所有的key取出来作为列表的元素

dog = {'name': '旺财', 'age': 3, 'kind': '中华田园犬'}
list1 = list(dog)
print(list1)    # ['name', 'age', 'kind']

三、字典使用的相关方法

1.字典.clear() - 清空字典

dog = {'name': '大黄', 'age': 4, 'gender': '公狗', 'kind': '土狗'}
dog.clear()
print(dog)

2.字典.copy() - 拷贝字典,返回新的字典

dog = {'name': '大黄', 'age': 4, 'gender': '公狗', 'kind': '土狗'}
dog2 = dog.copy()
dog['name'] = '小黄'
print(dog2)

3.dict.fromkeys(序列, 值) - 创建新字典;将序列中的元素作为key,指定的值作为每个key的value,去创建一个新的字典

dict1 = dict.fromkeys(['name', 'age', 'gender'], 0)
print(dict1)

4.字典.items()、字典.values()、字典.keys()

1). 字典.keys() -> 获取字典所有的key并且返回, 返回的数据类型是序列但是不是列表

2). 字典.values() -> 获取字典所有的value并且返回,返回的数据类型是序列但是不是列表

3). 字典.items() -> 同时获取字典所有的key和value, 返回一个序列,序列中元素是有两个元素的元祖,这两个元素分别是key和value

dog = {'name': '大黄', 'age': 4, 'gender': '公狗', 'kind': '土狗'}
print(list(dog.keys()))   # ['name', 'age', 'gender', 'kind']
print(list(dog.values()))  # ['大黄', 4, '公狗', '土狗']
print(dog.items())    # dict_items([('name', '大黄'), ('age', 4), ('gender', '公狗'), ('kind', '土狗')])

5.字典.setdefault(key, value) - 字典中添加键值对(key存在的时候不会修改)

dog = {'name': '大黄', 'age': 4, 'gender': '公狗', 'kind': '土狗'}
dog.setdefault('color', '黄色')
print(dog)

dog.setdefault('name', '财财')
print(dog)

6.字典1.update(字典2) - 将字典2中的键值对更新到字典1中(不存在的就添加,存在的就覆盖)

dog = {'name': '大黄', 'age': 4, 'gender': '公狗', 'kind': '土狗'}
dict2 = {'name': '小明', 'height': 170}
dog.update(dict2)
print(dog)

练习2:

设置数据保存一个班级的信息: 班级名字、位置、所有的老师(名字、性别、QQ、职责)、

所有的学生(姓名、学校、电话、性别、年龄、紧急联系人(...))

class1 = {
    'class_name': 'python1906',
    'teachers': [
        {'name': '余婷', 'gender': '女', 'qq': '726550822', 'duty': '讲师'},
        {'name': '张老师', 'gender': '女', 'qq': '828333', 'duty': '班主任'}
    ],
    'students': [
        {
            'name': '小明',
            'school': '川大',
            'tel': '2382638',
            'contacts': {
                            'name': '张三',
                            'tel': '2327387',
                            'relationship': '父亲'
                        }
        },
        {
            'name': '小红',
            'school': '交大',
            'tel': '82939283',
            'contacts': {
                            'name': '李四',
                            'tel': '2327387',
                            'relationship': '母亲'
                        }
        }
    ]
}

for student in class1['students']:
    if student['name'] == '小明':
        print(student['contacts']['name'])

四、集合

1.什么是集合(set)

集合是容器型数据类型,将{}作为容器标志里面多个元素用逗号隔开: {元素1, 元素2, 元素3,...}
可变的(支持增删改)、无序的(不支持下标操作)

集合中的元素: 不可变的,唯一的(自带去重)

1.空集合

注意: {}表示空字典

x = {}
print(type(x))

set1是一个空集合

set1 = set()

2.集合中的元素

set2 = {1, 2, 'hus', (10, 2)}
print(set2)

集合中的元素不可变

 set3 = {[1, 2], 2, 'hus'}    # TypeError: unhashable type: 'list'

集合中的元素是唯一的

set4 = {1, 2, 'hus', 1}
print(set4)    # {1, 2, 'hus'}

2.增删改查

1)查 - 遍历集合

set5 = {23, 3, 5, 67, 8}
for x in set5:
    print(x)

2)增

a.添加单个元素: 集合.add(元素) - 在集合中添加指定元素

set5.add(100)
print(set5)

b.集合.update(序列) - 将序列中所有的元素添加到集合中

set5.update('abc')
print(set5)

set5.update({'name': '小明', 'age': 18})
print(set5)

3).删 - 删除元素

集合.remove(元素) - 删除集合中指定元素,元素不存在报错

集合.discard(元素) - 删除集合中指定元素, 元素不存在不报错

set5.remove(100)
print(set5)

set5.discard(67)
print(set5)
set5.discard(1000)

3.相关操作

1) in / not in

set5 = {23, 3, 5, 67, 8}
print(8 in set5)

2)len, set

set(序列) - 所有的序列都能转换成集合(元素不可变); 自动去重

list1 = [10, 23, 10, 25, 30, 12, 23]
list1 = list(set(list1))
print(list1)

五、数学集合运算

1.数学集合运算: 并集(|), 交集(&), 差集(-), 对称差集(^), >/<(包含关系)

set1 = {1, 2, 3, 4, 5, 6}
set2 = {4, 5, 6, 7, 8}

1)并集: 集合1 | 集合2 -> 将两个集合合并在一起产生一个新的集合

print(set1 | set2)   # {1, 2, 3, 4, 5, 6, 7, 8}

2)交集: 集合1 & 集合2 -> 获取两个集合的公共部分产生一个新的集合

print(set1 & set2)   # {4, 5, 6}

3)差集: 集合1 - 集合2 -> 获取集合1中去掉集合2剩下的部分

print(set1 - set2)    # {1, 2, 3}
print(set2 - set1)    # {8, 7}

4)对称差集:集合1 ^ 集合2 -> 获取集合1和集合2合并后去掉公共部分剩下的部分

print(set1 ^ set2)    # {1, 2, 3, 7, 8}

5) 集合1 > 集合2 - 判断集合1中是否包含集合2

集合1 < 集合2 - 判断集合2中是否包含集合1

set3 = {5, 6, 7, 8, 9}
set4 = {1, 2}
print(set3 > set4)    # False
print(set3 > {5, 6})  # True
print(set3 > {5, 6, 1})   # False

你可能感兴趣的:(Day6-python字典和集合)