本周python学习
一、练习
from openpyxl import load_workbook
wb = load_workbook("./class3/电影导演演员信息表.xlsx")
ws = wb.worksheets[0]
actor_movies = {}
for index, row in enumerate(ws.rows):
if index == 0:
continue
film = row[0].value
actors = row[ws.max_column - 1].value.split(',')
for actor in actors:
actor_movies[actor] = actor_movies.get(actor, set()) | {film}
print(actor_movies)
more_actor = {}
for i in range(1, len(actor_movies)):
for j in range(i + 1, len(actor_movies) + 1):
act_one = "演员" + str(i)
act_two = "演员" + str(j)
movie_one = actor_movies.get(act_one)
movie_two = actor_movies.get(act_two)
if movie_one & movie_two:
more_actor.update({act_one + "," + act_two: len(movie_one & movie_two)})
list_actor = sorted(more_actor.items(), key=lambda x: x[1], reverse=True)
print("共同演出电影的数量最多两个演员是:", list_actor[0][0], '\n共同演出了:', list_actor[0][1], '场')
二、知识学习
1.set
1.1概述
set()函数创建一个无序不重复元素集,相关的运算有:交、差、并、补等
set 语法:
classset([iterable])
1.2 代码举例
aihao=set(['dance','sing'])
aihao=aihao|{'play'}
item="read" aihao=aihao|{item}
print(aihao)
import random
a=set() #创建一个空集合
x = set('runoob')
y = set('google')
print(x, y)
print(x | y) #并运算
print(x & y) #交运算
print(x-y)#差运算
-
交集&:x&y,返回一个新的集合,包括同时在集合 x 和 y 中的共同元素。
-
并集 |:x|y,返回一个新的集合,包括集合 x 和 y中所有元素。
-
差集 -:x-y,返回一个新的集合,包括在集合 x 中但不在集合 y 中的元素。
-
补集:xy,返回一个新的集合,包括集合 x 和 y 的非共同元素。
2.tuple
tuple 元组不可以修改,速度比 list[]
tuple 元组不可以修改,速度比 list[]快
tup1=('zhang','dance','singing')
for index,item in enumerate(tup1):
print(index,item)
3.Enumerate()
3.1 enumerate()简介及语法
enumerate()是 Python 中的内置函数,将可迭代/可遍历的的数据对象组合为
一个索引序列,同时列出数据和数据下标,一般用在 for 循环中
enumerate()语法:
enumerate(sequence,[start=0])
3.2 代码案例
list1 = ["这", "是", "一个", "测试"]
for index, item in enumerate(list1):
print(index, item)
运行结果:
0 这
1 是
2 一个
3 测试
4. Dict
4.1 Dict 概述
字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值 key 和 value 对用冒
号:分割,每个键值对之间用逗号,分割,整个字典包括在花括号{}中 ,格式如下所示:
d = {key1 : value1, key2 : value2 }
键一般是唯一的,如果重复最后的一个键值对会替换前面的,值不需要唯一
4.2 代码案
# 字典定义及初始化 1
dict=dict()#初始化一个空字典
dict['a']={'1','2'}
print(dict)
# 字典定义及初始化 2
dict = {'a': 1, 'b': 2, 'b': '3'}
print(dict['b'])
keys=dict.keys()#输出字典的关键字