tuple-dict-set

一、复习

1. 列表(list)

容器型数据类型(序列), 可变、有序

2. 元素

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

3. 元素的增删改查(*)


    1. 查单个元素:列表[下标]
      查部分元素(切片):列表[开始下标:结束下标:步长], 列表[:], 列表[::-1]
      遍历:直接遍历、遍历下标

    1. 列表.append(元素)、 列表.insert(下标, 元素)

    1. del 列表[下标]
      列表.remove(元素)
      列表.pop() 列表.pop(下标)

    1. 列表[下标] = 新值

4. +, *, ==, !=, in/not in, len(), list()

5. 列表常用方法

    1. count
      列表.count(元素) -- 统计列表中指定元素的个数,返回一个整数
nums = [1, 34, 1, 6, 8, 1]
print(nums.count(1))
    1. extend
      列表.extend(序列) -- 将序列中的元素全部添加到列表中
nums.extend('abc')
print(nums)

nums.extend([100, 'abc', 'name'])
print(nums)
    1. index
      列表.index(元素) -- 获取指定元素对应的下标(如果元素有多个只取第一个)
      注意:如果元素不存在会报错!
nums = [100, 60, 34, 100]
print(nums.index(34))
    1. reverse
      列表.reverse() -- 反向列表(直接修改原列表)
      reversed(序列) -- 反向序列,不修改原序列而是产生新的序列(迭代器)
nums = [100, 60, 34, 101]
nums.reverse()
print(nums)

nums = [100, 60, 34, 101]
new_nums = reversed(nums)
print(nums, list(new_nums))

str1 = 'hello'
new_str = reversed(str1)
print(str1, ''.join(list(new_str)), str1[::-1])

# 字符串.join(序列)
    1. sort
      列表.sort() -- 将列表中的元素升序排序(从小到大)
      列表.sort(reverse=True) -- 将列表中的元素降序排序(从大到小)
      sorted(序列) -- 排序的时候不修改原序列,产生新的序列
      注意: 能够进行排序的列表要求列表中的元素类型一致,并且支持比较运算
# sort
nums = [100, 60, 34, 101]
# nums.sort()
nums.sort(reverse=True)
print(nums)

# sorted
nums = [100, 60, 34, 101]
new_nums = sorted(nums)       # 从小到大排序
print(nums)   # [100, 60, 34, 101]
print(new_nums)   # [34, 60, 100, 101]

new_nums = sorted(nums, reverse=True)     # 从大到小排序
print(new_nums)   # [101, 100, 60, 34]

str2 = 'helloworlda'
new_str = sorted(str2)
print(new_str)    # ['a', 'd', 'e', 'h', 'l', 'l', 'l', 'o', 'o', 'r', 'w']
print(''.join(new_str))   # adehllloorw
    1. clear
      列表.clear() -- 删除列表中所有的元素(清空列表)
nums = [100, 60, 34, 101]
print(id(nums))
# nums = []
nums.clear()
print(nums, id(nums))
    1. copy
      列表.copy() -- 相当于列表[:], 将列表中的元素拷贝一份产生一个新的列表(浅拷贝)
nums = [100, 60, 34, 101]
new_nums = nums.copy()
print(nums, new_nums)
print(id(nums), id(new_nums))

new_nums2 = nums     # 一个变量给另一个变量赋值,赋的是地址
new_nums2.insert(0, 1000)
print(new_nums2, nums)

二、作业评讲

1. 已知一个数字列表,将所有元素乘二。

例如:nums = [1, 2, 3, 4] —> nums = [2, 4, 6, 8]

nums = [1, 2, 3, 4]
for index in range(len(nums)):
    nums[index] *= 2
print(nums)

2. 有一个长度是10的列表,数组内有10个人名,要求去掉重复的

例如:names = ['张三', '李四', '大黄', '张三'] -> names = ['张三', '李四', '大黄']

# 方法一:
names = ['张三', '李四', '大黄', '张三']
new_names = []
for name in names:
    if name not in new_names:
        new_names.append(name)
names = new_names
print(names)
"""
names = ['张三', '李四', '大黄', '张三']
new_names = []
name = '张三';  new_names = ['张三']
name = '李四';  new_names = ['张三', '李四']
name = '大黄';  new_names = ['张三', '李四', '大黄']
name = '张三';  new_names = ['张三', '李四', '大黄']
"""

# 方法二:
names = ['张三', '李四', '大黄', '张三', '张三', '李四']
for name in names[:]:
    if names.count(name) > 1:
        names.remove(name)
print(names)

8. 用一个列表来保存一个节目的所有分数,求平均分数(去掉一个最高分,去掉一个最低分,求最后得分)

scores = [97, 98, 99, 94, 93, 60, 108, 60]
avge = (sum(scores) - max(scores) - min(scores)) / (len(scores) - 2)

print(sum([1, 2, 3, 4]))

9. 有两个列表A和B,使用列表C来获取两个列表中公共的元素

A = [1, 'a', 4, 90]
B = ['a', 8, 'j', 1]
C = []
for item in A:
    if item in B:
        C.append(item)

10. 有一个数字列表,获取这个列表中的最大值.(注意: 不能使用max函数)

list1 = [97, 98, 99, 94, 93, 60, 108, 60]
max1 = list1[0]
for item in list1[1:]:
    if item > max1:
        max1 = item
print(max1)

11. 获取列表中出现次数最多的元素

例如:nums = [1, 2, 3,1,4,2,1,3,7,3,3] —> 打印:3

nums = [1, 2, 3, 1, 4, 2, 1, 3, 7, 3, 3, 1, 1]
max_count = 0     # 保存最大个数
num = None    # 最大个数对应的元素, None - 空值(没有)
for item in nums:
    count = nums.count(item)
    if count > max_count:
        max_count = count
        num = item

print('出现次数最多的元素:%d, 次数是:%d' % (num, max_count))

三、元祖

1. 什么是元祖(tuple)

元祖是python提供的容器型数据类型(序列), 不可变(特色), 有序
元祖就是不可变的列表, 一般保存一些不让修改的数据
(元素1, 元素2, 元素3....)

2. 元素

空的元祖

tuple1 = ()
print(tuple1, type(tuple1))
    1. 元素个数是1的元祖: 如果一个元祖中只有一个元素,这个元素后面必须加逗号!
tuple2 = (10,)
print(tuple2, type(tuple2))
    1. 元祖数据中小括号可以省略。(多个数据直接用逗号隔开,表示的是一个元祖)
tuple3 = 10, 23, 89, '小明'
print(tuple3, type(tuple3))

3. 获取元素: 和列表一样

tuple2 = ('周一', '周二', '周三', '周四', '周五')
print(tuple2[1])
print(tuple2[2:])
for item in tuple2:
print(item)

    1. 让变量的个数和元祖中元素的个数保持一致,来一一获取元祖中每个元素的值
point = (100, 50)
x, y = point
print('x:', x, 'y:', y)

a, b, c = 10, 20, 30    # a, b, c = (10, 20, 30)
    1. 让多个变量同时获取元祖中的元素的时候,可以在一个变量前加将这个变量变成一个列表,来获取不带的变量获取后剩下的数据。(注意,带*的变量只能有一个)
student = ('小明', 18, 89, 68, 89, 90, 'abc')
name, age, *scores = student
print(name, age, scores)   # 小明 18 [89, 68, 89, 90, 100]

name, *scores, age, a = student
print(name, age, scores, a)   # 小明 90 [18, 89, 68, 89] 100

*items, a, b = student
print(items, a, b)    # ['小明', 18, 89, 68, 89] 90 abc

四、字典

1. 什么是字典(dict)

字典是python提供的容器型数据类型(序列), 可变, 无序

2. 字典中的元素

{键值对1, 键值对2, 键值对3,...} - 字典的元素就是键值对
键值对 - 以'键:值'的形式成对出现
键(key) - 要求不可变,唯一 (建议用字符串作为key, 用来对值进行说明和区分的)
值(value) - 任何类型的数据都可以作为值

dict1 = {10: 100, 'name': 100, (1, 2): 100, 'a': 'abc', 'b': True, 'c': [1, 2], 'd': {'a': 2}}
print(dict1)

dict2 = {10: 100, 'name': 100, [1, 2]: 100}  # TypeError: unhashable type: 'list'
dict1 = {10: 100, 'name': 100, {'a': 1}: 100}  # TypeError: unhashable type: 'dict'

dict1 = {10: 100, 'name': 100, (1, 2): 100, 10: 200}
print(dict1)   # {10: 200, 'name': 100, (1, 2): 100}

3. 元素的操作

    1. 查 - 获取值
    • a. 字典[key] - 获取字典中key对应的value。(如果key不存在会报错!)
    • b. 字典.get(key) - 获取字典中key对应的value。(如果key不存在不报错,结果是None)
      字典.get(key, 默认值) - 获取字典中key对应的value。(如果key不存在不报错,结果是默认值)
dog = {'name': '旺财', 'color': '黄色', 'age': 3, 'type': '土狗'}
print(dog['type'])
# print(dog['gender'])     # KeyError: 'gender'

print(dog.get('name'))
print(dog.get('gender'))     # None
print(dog.get('age', 100))
print(dog.get('gender', '公狗'))   # 公狗

3. 遍历字典

    1. 直接通过for循环遍历字典的时候,获取到的是所有的key
# 1.直接遍历(只用这个)
for key in dog:
    print(key, dog[key])

# 2.间接遍历
print('===================')
print(dog.values())
for value in dog.values():
    print(value)

print('====================')
print(dog.items())
for key, value in dog.items():
    print(key,  value)
    1. 增/改
      字典[key] = value - 如果key存在, 修改key对应的值; 如果key不存在,添加键值对
class1 = {'name': 'py1902', 'address': '19楼5教室'}
print(class1)   # {'name': 'py1902', 'address': '19楼5教室'}

# 增
class1['num'] = 50
print(class1)    # {'name': 'py1902', 'address': '19楼5教室', 'num': 50}

# 改
class1['name'] = 'python1902'
print(class1)
    • a. del 字典[key] - 删除字典中指定key对应的键值对。如果key不存在会报错
    • b. 字典.pop(key) - 取出字典中key对应的值。如果key不存在会报错
class2 = {'name': 'python1902', 'address': '19楼5教室', 'num': 50}
del class2['num']
print(class2)    # {'name': 'python1902', 'address': '19楼5教室'}

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

4. 字典相关操作

    1. 运算符:不支持数学运算,比较运算符只支持比较相等不支持比较大小
      print({'a': 100, 'b': 10} == {'b': 10, 'a': 100}) # True
    1. in / not in
      key in 字典 - 判断字典中是否存在指定的key
class2 = {'name': 'python1902', 'address': '19楼5教室', 'num': 50}
print('name' in class2)    # True
print(50 not in class2)    # True
    1. len
      print(len(class2))
    1. dict
      能转换成字典的数据要求: 数据本身是序列,序列中的每个元素也是长度是2的序列,并且小序列中第一个元素是不可变的
data = [(1, 2), ['a', 23]]
print(dict(data))

dict2 = {'a': 10, 'b': 20}
print(list(dict2))    # ['a', 'b']

5. 相关方法

    1. clear
      字典.clear() - 清空字典
dict2 = {'a': 10, 'b': 20}
dict2.clear()
print(dict2)
  • 2)copy
    字典.copy() - 拷贝字典中的键值对产生一个新的字典
dict2 = {'a': 10, 'b': 20}
dict3 = dict2
dict3['a'] = 100
print(dict2)   # {'a': 100, 'b': 20}

dict2 = {'a': 10, 'b': 20}
dict3 = dict2.copy()
dict3['a'] = 100
print(dict2)   # {'a': 10, 'b': 20}
    1. fromkeys
      dict.fromkeys(序列, 值) - 创建一个新的字典,字典的key是序列的元素, key对应的value是值
new_dict = dict.fromkeys('hello', 100)
print(new_dict)
    1. keys, values, items
      字典.keys() - 获取字典中所有的key, 结果是一个序列
      字典.values() - 获取字典中所有的value, 结果是一个序列
      字典.items() - 获取字典中中的key和value, key和value以元祖的形式返回
students = {'name': '张三', 'age': 18, 'stu_id': 'stu001', 'gender': '女'}
print(students.keys())
print(students.values())
print(students.items())
    1. setdefault
      字典.setdefault(key, value) - 添加键值对(不能修改)
students.setdefault('tel', '15300022783')
print(students)
    1. update
      字典1.update(字典2) - 使用字典2中的键值对去更新字典1(不存在添加、存在修改)
dict1 = {'a': 1, 'b': 2, 'c': 3}
dict2 = {'b': 200, 'd': 300, 'e': 400}
dict1.update(dict2)
print(dict1)   # {'a': 1, 'b': 200, 'c': 3, 'd': 300, 'e': 400}

六、集合

1. 什么是集合(set)

容器型数据类型(序列), 可变、无序

2. 集合中的元素

{元素1, 元素2, 元素3,...}
元素: 不可变、唯一(自带去重功能)
注意: {}不是能表示空的集合,set() - 空集合

set1 = set()
set2 = {1, 'abc', (1, 3), False, 1, 1, 1}
print(set2)   # {False, 1, (1, 3), 'abc'}

# 集合可以去重
str1 = 'hekskfahhheuwjseaaa'
print(''.join(set(str1)))

list1 = [1, 34, 34, 2, 2]   # hfkaweujs
print(list(set(list1)))   # [1, 34, 2]

3. 元素相关操作


    1. 集合不能单独获取指定的某一个元素, 只支持遍历
set3 = {12, 34, 56, 2, 7, 88}
for x in set3:
    print(x)

    1. 集合.add(元素) - 往集合中添加一个元素
      集合.update(序列) - 将序列中的元素添加到集合中(自带去重)
set1 = {1}
print(set1)
set1.add(100)
print(set1)

set1.update('abc')
print(set1)

set1.update({'name': '张三', 'age': 20})
print(set1)

    1. 集合.remove(元素) - 删除集合中指定的元素。(元素不存在会报错!)
set4 = {1, 'b', 100, 'a', 'age', 'c', 'name'}
set4.remove(100)
print(set4)
  • *4. 数学集合运算
set1 = {1, 2, 3, 4, 5, 6}
set2 = {4, 5, 6, 7, 8}
# 1) 并集: |
集合1 | 集合2   -  将两个集合中的元素合并产生新的集合
print(set1 | set2)

# 2) 交集: &  - 求两个集合公共的部分
print(set1 & set2)  # {4, 5, 6}

# 3) 差集/相对补集: 集合1 - 集合2   --- 获取集合1中除了集合2以外的部分
print(set1 - set2)  # {1, 2, 3}
print(set2 - set1)  # {7, 8}

# 4) 对称差分: 集合1^集合2    --- 两个集合除了公共部分以外的部分
print(set1 ^ set2)

# 5) 包含关系
"""
集合1 >= 集合2   -  集合1中是否包含集合2
集合1 <= 集合2   -  集合2中是否包含集合1
"""
print({5, 6, 7, 8, 9} >= {1, 2, 3})    # False
print({5, 6, 7, 8, 9} >= {5, 9})    # True
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容