2019-01-03元祖、集合和字典

一.元祖

1.什么是元祖(tuple)

python提供的容器型数据类型,不可变并且有序。(元祖就是不可变的列表)
不可变 - 不支持增删改,只支持查。
例如:
point = (100, 30)

a.空的元祖: ()

tuple1 = ()

b.只有一个元素的元祖

print(tuple2, type(tuple2))

有序 - 每个元素对应一个确定的下标

2.字面量和元素

(元素1, 元素2, 元素3...)
其中的元素可以是任何类型的数据,并且类型可以不一样,同样的元素可以有多个。
例如:
tuple3 = 1, 2, 3

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

tuple4 = ('成都', '达州', '绵阳', '南充', '广元')

a.获取单个元素

print(tuple4[1], tuple4[-1])

b.获取部分

print(tuple4[0:3])
print(tuple4[::-1])

4.补充:特殊的获取方式

a. 变量1,变量2... = 元祖 -- 用前面的变量依次获取元祖元素的值。(要求前###面变量的个数和元祖元素的个数一致)

point = (100, 200, 10)
x, y, z = point    # x,y = (100, 200)  <==> x, y = 100, 200
print(x, y, z)

b. 变量1, 变量2 = 元祖 -- 通过带的变量获取元祖中剩余的部分;

注意:这个结构中带的变量只能有一个,不带的变量可以有多个。

name, *scores = ('小明', 100, 89, 67, 99)
print(name, scores)

name, num, *scores = ('小明', 100, 89, 67, 99)
print(name, num, scores)

*info, num1, num2 = ('小明', 100, 89, 67, 99)
print(info, num1, num2)

info1, *nums, num1 = ('小明', 100, 89, 67, 99)
print(nums)

c. 补充:*的用法

取元祖和列表中的数据

nums = (1, 2, 3)
nums2 = [11, 22, 33]
print(*nums, *nums2)

4.相关运算(和列表一样)

+,*
in / not in
len(), max(), min(), sum(), tuple()

tuple1 = (1, 2, 3)
tuple2 = ('aa', 'bb')
print(tuple1 + tuple2)
print(tuple1*3)

print('aaa' in tuple2)

5.排序

a. sorted(序列) - 对序列中的元素排序,产生一个新的列表(不管是什么序列,排完后最后都是列表)

注意:列表.sort() -- 修改原列表中元素的顺序; sorted(列表) -- 产生一个新的列表

nums = (1, 34, 89, 9)
new_nums = sorted(nums, reverse=True)
print(new_nums, tuple(new_nums),nums)

new_strs = sorted('skjhabssnssalewz')
print(str(new_strs), ''.join(new_strs))

b. join的使用

字符串.join(序列) - 将序列中的元素取出,用指定的字符串连接在一起。要求序列中的元素必须是字符串

new_str = ''.join(['aks', 'bos', 'cous'])
print(new_str, type(new_str))


list1 = [1, 345, 90, 9]
new_list = list1.sort()    # None; sort不会产生新的列表
print(list1, new_list)

二.字典

1.什么是字典(dict)

python提供的容器型数据类型,可变并且无序
可变 - 支持元素的增删改
无序 - 不支持下标操作

2.字面量和元素

用大括号括起来,里面多个键值对,每个键值对用逗号隔开。键值对就是字典的元素。
{key1:value1, key2:value2, key3:value3...}

键值对- 键/key:值/value(键值对); 键值对必须成对出现,而且脱离字典单独出现没有意义。
键/key - 必须是不可变的, 而且是唯一的。实际一般将字符串作为键
值/value - 可以是任意类型的数据

注意:字典存储数据,实质是通过值来存储的。key是值对应的标签和获取值的方式。

3.什么时候使用字典:多个没有相同意义的数据(需要区分),就使用字典。

例如:保存一个人的不同信息,一辆车的不同信息。
什么时候使用列表: 存储的多个数据是有相同意义的数据(不需要区分),就使用列表.例如:保存一个班的学生信息,保存所有的价格。

person = ['xiaohua', 18, 'girl', 160, 90, 89]
print(person[1])
person[-2]

person = {'name': 'xiaohua', 'age': 18, 'sex': 'girl', 'height': 160, 'weight': 90, 'score': 89}
print(person['age'])

4.字典元素的增删改查

a.查(获取值)

注意:字典中的键值对单独拎出来没有任何意义

1.字典[key] - 获取字典中key对应值

注意: 当key不存在的时候,会报KeyError

b.

字典.get(key) - 获取字典中key对应值; 当key不存在的时候不会报错,并且取到一个默认值None
字典.get(key,值1) - 获取字典中key对应值;当key不存在的时候不会报错,并且取到指定的值1

print(car.get('type'))
print(car.get('speed'))

print(car.get('color', '红色'))   # 黄色
print(car.get('speed', 0))       # 0

c.遍历字典

注意: 直接通过for-in遍历字典取到的是key

dict1 = {'a': 100, 'b': 200, 'c': 300}

  1. 遍历字典取到的是key(推荐使用)
for key in dict1:
   print(key, end=' ')
    print(dict1[key])
print(dict1.values(), dict1.items())
  1. 遍历字典的values(),获取所有的值
for value in dict1.values():
    print(value)

3.遍历字典的items(),直接获取key和value(不建议使用)

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

2.增、改

字典[key] = 值 - 当key不存在就是添加键值对; 当key存在的时候就是修改key对应的值

movie = {'name': '喜羊羊与灰太狼', 'type': '卡通', 'time': 120}

a. 添加

movie['score'] = 7.9
print(movie)

b. 修改

movie['type'] = '搞笑'
print(movie)

3.删(删除键值对)

a.

del 字典[key] - 删除字典中指定的key对应的键值对

b.

字典.pop(key) - 取出字典中key对应的值

del movie['time']
print(movie)

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

4.比较运算

==, !=
注意:判断两个字典是否相等,只看键值对是否一样,不管键值对的顺序;
字典不支持>和<符号

print({'a': 11, 'b': 22} == {'b': 22, 'a': 11}) # True

a. in / not in

key in 字典 --- 判断字典中指定的key是否存在
key not in 字典 --- 判断字典中指定的key是否不存在

dict1 = {'a': 1, 'z': 2, 'c': 3}
print('a' in dict1)  # True
print(1 in dict1)    # False

5. len(), max(), min()

a.dict(数据) - 数据要求是序列,并且序列中的元素都是有两个元素的子序列

1.获取字典中键值对的个数

print(len(dict1))

2. 获取字典中key的最大值/最小值

print(max(dict1), min(dict1))

3. 将列表转换成字典

print(dict([(1, 2), ('a', 'b'), [10, 'abc']]))

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}

4. 字典转列表/元祖/集合都是将字典中的key取出来作为列表/元祖/集合的元素

print(list(dict2)) # ['name', 'color', 'height']

6.相关方法

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

注意:清空容器推荐使用clear操作,而不是重新赋一个空的容器

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}
print(id(dict2))
dict2.clear()
print(dict2, id(dict2))

b.只有容器本身不存在的时候,可以使用

dict2 = {}
print(id(dict2))

c.字典.copy() - 复制字典的中的元素,产生一个新的字典

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}

d. 直接赋值,修改其中一个的元素,会影响另外一个

dict3 = dict2
print(dict3)
dict3['name'] = '小明'
print(dict3)
print(dict2)

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}

e. 拷贝赋值,会产生新的地址,赋值后相互不影响

dict4 = dict2.copy()
print(dict4)
del dict4['color']
print(dict4)
print(dict2)

f. dict.fromkeys(序列, 值) -- 以序列中所有的元素作为key,指定的值作为value创建一个新的字典

new_dict = dict.fromkeys('abc', (10, 20, 30))
print(new_dict)

new_dict = dict.fromkeys(['name', 'age', 'tel'], 0)
print(new_dict)

g.

字典.keys() - 将字典所有的key取出产生一个新的序列
字典.values() - 将字典所有的value取出产生一个新的序列
字典.items() - 将字典所有的key和value做为一个元祖取出产生一个新的序列

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}
print(dict2.keys(), dict2.values(), dict2.items())

h.字典.setdefault(key, value=None)

字典.setdefault(key) - 当key不存在的时候,添加键值对key:None
字典.setdefault(key, value) - 当key不存在的时候,添加键值对key:value
注意:这个操作当key存在的时候,不会修改

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}

dict2.setdefault('name2', '小胡')
dict2.setdefault('sex')
print(dict2)

i. 字典1.update(字典2) - 使用字典2中的键值对去更新字典1;

如果字典2中的key,字典1中本身存在就是修改,不存在就添加

dict2 = {'name': 'xiaohua', 'color': 'black', 'height': 170}
dict2.update({'height': 180, 'age': 18})
print(dict2)

dict2.update([('a', 100), ('age', 30)])
print(dict2)

三.集合

1.什么是集合(set)

可变的,无序的; 元素是唯一并且不可变

2.字面量

{元素1, 元素2, 元素3...}

3.增删改查

set1 = {1, 38, 90, 8}

a.查

集合不能单独的获取单个元素,只能一个一个的遍历

for item in set1:
    print(item)

b.增

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

set1 = {1, 38, 90, 8}
set1.add('abc')
print(set1)
set1.update('abc')
print(set1)

set1.update({'aa': 10, 'bb': 20})
print(set1)

c.删

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

set1 = {1, 38, 90, 8}
set1.remove(90)
print(set1)

d.数学集合运算

交集(&): 获取两个集合公共的元素产生一个新的集合
并集(|): 将两个集合中的元素合并在一起产生一个新的集合
差集(-): 集合1 - 集合2:去掉集合1中包含集合2的部分,剩下的产生一个新的集合
补集(^): 将两个集合合并在一起,去掉公共部分,剩下的部分产生一个新的集合
子集的判断: 集合1>集合2 -> 判断集合1中是否包含集合2, 集合1<集合2 - 判断集合1中是否包含集合2

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

推荐阅读更多精彩内容