漫步人生路之Python旅途(五)高山流水

2019-01-05 13:10:52来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

字典dict
字典是由大括号{键:值}组成.字典是无序的.字典的键是不可变的,不能使用列表作为键.但可以使用元祖作为字典的键.例如:

dict_ = {"test":"Hello World"}

str_ = "hello"
dict_ = {str_:"霍元甲"}      # 这是正确的

list_ = [1,2,3]
dict_ = {list_:"西游记"}     # 这是错误的

tuple_ = (1,2,3)
dic = {tuple_:"红楼梦"}      # 这是正确的

dict_ = {1:"陈真"}           # 这是正确的

dict_ = {True:"霍东阁"}      # 这是正确的

dict_1 = {"字典":""}
dict_ = {dict_1:"三国演义"}   # 这是错误的

新增

setdefault(键,值):如果只写键不写值将打印该键所对应的值,如果没有找到键返回Note

# dict['键'] = '值'
dict_ = {"电视剧":"笑傲江湖"}
dict_["电影"] = "黄飞鸿"

dict_.setdefault("新增","我是新增的")  # setdefault()函数添加键值对
print(dic)

# 打印如下内容:
{'电视剧': '笑傲江湖', '电影': '黄飞鸿', '新增': '我是新增的'}

# 如果setdefault(键)如果只写键不写值是查询键的值.
print(dict_.setdefault("新增"))

# 打印如下内容:
我是新增的 

fromkeys(字典键列表,值):如果值是列表,是可变的那么如果更改列表中的值会影响整个字典键中的值.

dict_ = {}
list_str = ["name","age"]
dict_ = dict_.fromkeys(list_str,[1,2,3])
dict_["name"].append(4)    # 向dict_["name"]中追加元素4                                            
print(dic)

# 打印内容如下:
{'name': [1, 2, 3, 4], 'age': [1, 2, 3, 4]}     # 发现age键的值也发生了改变,和name键的值一样

可以通过重新给键赋值的方法,摆摊更改键中列表的值,而影响整个字典中键的值.

dic={}
s = ["name","age"]
dic = dic.fromkeys(s,[1,2,3])
dic["name"] = [10,2]
print(dic)

# 打印内容如下:
{'name': [10, 2], 'age': [1, 2, 3]}

删除

pop(键):删除字典中的键值对

dict_ = {"电视剧":"西游记","电影":"少林寺"}
print(dict_.pop("test"))  # pop()如果找不到键会报错

# 打印内容如下:
KeyError: 'test'     # 没有找到键

 给pop(键,提示信息):添加个参数,用于在没有找到键时提示给用户

dict_ = {"电视剧":"西游记","电影":"少林寺"}
print(dict_.pop("test","没有找到该键"))  # 可以在pop(键,提示信息)

# 打印内容如下:
没有找到该键       # 用于提示用户这个键没有找到.

pop(键,提示语句)是有返回值的,可以返回被删除的键的值.

popitem():没有参数,返回值是被删除的键值对,Python3.6以上版本删除最后一项键值对,其它版本是随机删除一组键值对.

dict_ = {"电视剧":"西游记","电影":"少林寺"}
dict_.popitem()
print(dic)

查找

keys():打印字典所有的键

dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.keys())

# 打印内容如下:
dict_keys(['电视剧', '电影'])

values():打印字典所有的值

dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.values())

# 打印内容如下:
dict_values(['霍元甲', '黄飞鸿'])

items():打印字典所有的键值对
dic = {"电视剧":"霍元甲","电影":"黄飞鸿"}


dict_ = {"电视剧":"霍元甲","电影":"黄飞鸿"}
print(dict_.items())
# 打印内容下:
dict_items([('电视剧', '霍元甲'), ('电影', '黄飞鸿')])

解构(常用操作)

a,b,c = 1,2,3
print(a,b,c)
print(type(a),type(b),type(c))

# 打印效果如下:
1 2 3
<class 'int'> <class 'int'> <class 'int'>

 

list_ = ["a","b","c"]
list_ = 1,2,3
print(list_,type(list_))

# 打印效果如下:
(1, 2, 3) <class 'tuple'>

 

list_ = "a","b","c"
print(list_,type(list_))
# 打印内容如下:
('a', 'b', 'c') <class 'tuple'>

set集合:无序列表,集合的特性是没有重复数据.
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典的,还有set集合的值必须是不可变的如:整型,字符串,元祖.不能是列表,字典等可被修改的数据.如下操作:

set_1 = {1,2,3}            # 正确
set_2 = set()              # 定义一个空列表
set_3 = {"a","b","c"}      # 正确
set_4 = {True,False}       # 正确
set_5 = {1,2,"a",(1,2,3)}  # 正确
set_6 = {1,2,"a",[1,2,3]}  # 错误的赋值方式,list是可变的
print(set_3)

# 打印内容如下:
TypeError: unhashable type: 'list'

 

set_7 = {1,2,"a",{"字典":""}} # 错误的赋值方式,dict是可变的
print(set_7)

# 打印内容如下:
TypeError: unhashable type: 'dict'

 

set_8 = {1,2,"a",{5,7,9}} # 错误的赋值方式,set是可变的
print(set_3)

# 打印内容如下:
TypeError: unhashable type: 'set'

set集合中常用的方法:
新增
add():向集合中添加数据,参数必须是不可改变的.参数类型参考set的赋值.

set_ = {1,2,3}
set_.add(4)
print(set_)

#打印如下内容:
{1, 2, 3, 4}

 

set_ = {1,2,3}
list_ = ["a","n"]

set_.add(list_)   # 因为列表是可变的,所以不能用作集合的值

# 打印内容如下:
TypeError: unhashable type: 'list'

更新

update(可迭代对象):向集合中添加可迭代数据

set_1 = {1,2,"a"}
set_1.update([10,20,3])
set_1.update(("defghigk"))
set_1.update((10,20,30))
set_1.update({"字典":""})
print(set_1)

# 打印内容如下
{1, 2, 3, 10, 'g', 'h', 'd', 'a', 'i', 'k', 20, 'f', 'e', '字典', 30}

删除:

set_3 = {1,2,"a"}
del set_3   # 因为集合是无序的没有下标,所以用del只能删除集合

pop():随机删除一个元素(测试如果有0,默认先删除0.其它随机)

set_3 = {1,2,"a"}
set_3.pop()     # 随机删除一个元素
print(set_3)

# 打印内容如下:
{2, 'a'}

remove(元素):根据元素删除元素,如果删除一个没有的元素会报错

set_3 = {1,2,"a"}
set_3.remove(2)
print(set_3)

# 打印内容如下:
{1, 'a'}

集合的其它操作:
交集:两个集合里面都存在的数据,可以使用&或者使用函数intersection来获取两个集合的交集.

set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 & set_2  # 通过&符号获取set_1和set_2的交集
print(set_3)

# 打印内容如下:
{2, 3}

# 通过函数intersection()获取交集
set_1 = {"a","b","c","d"} 
set_2 = {"z","c","a"}
set_3 = set_1.intersection(set_2) # 通过函数获取set_1和set_2的交集 print(set_3) # 打印内容如下: {'a', 'c'}

并集:将两个集合进行合并,如果两个元素相同合并一个城元素,如果两个元素不相同就添加进来.使用|符号或者使用union()函数

set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 | set_2 # 使用|符号获取两个集合的并集
print(set_3)

# 打印内容如下:
{1, 2, 3, 4, 40, 10}

# 通过函数union()获取两个集合的并集
set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.union(set_2) # 使用union()函数获取两个数的并集
print(set_3)

# 打印内容如下:
{'b', 'z', 'a', 'c', 'd'}

差集:用第一个集合减去第二个集合里共同存在的元素.使用符号-或者使用函数difference()来实现

set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 - set_2 # 通过符号-将set_1和set_2共同存在的元素从set_1中删除,如果set_2在前就从set_2中删除
print(set_3)

# 打印内容如下:
{1, 4}

set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.difference(set_2) # 通过函数difference()实现
print(set_3)

# 打印内容如下:
{'d', 'b'}

反交集:将两个集合进行合并,并去除相同的元素,使用符号^或者symmetric_difference

set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 ^ set_2  # 使用^符号实现
print(set_3)

# 打印内容如下:
{1, 4, 40, 10}

set_1 = {"a","b","c","d"}
set_2 = {"z","c","a"}
set_3 = set_1.symmetric_difference(set_2)  # 使用函数实现
print(set_3)

# 打印内容如下:
{'z', 'b', 'd'}

子集:一个集合是否在另一个集合中,也就是一个集合是否被另一个集合所包含.如果被另一个集合包含返回True,否则返回False.使用<符号或者issubset()

set_1 = {1,2,3,4}
set_2 = {10,2,40,3}
set_3 = set_1 < set_2  # 使用<符号实现
print(set_3)
# 打印内容如下:
False

set_1 = {"a","b","c","d"}
set_2 = {"z","c","a","b","d","e"}
set_3 = set_1.issubset(set_2)    # 使用函数实现
print(set_3)

# 打印内容如下:
True

超级:与子集相反,判断一个集合是否包含另一个集合,如果包含另一个集合返回True否则返回False.使用符号>或者issuperset()

set_1 = {1,2,3,4,10,50,40}
set_2 = {10,2,40,3}
set_3 = set_1 > set_2   # 使用>符号
print(set_3)

# 打印内容如下:
True

set_1 = {"a","b","c","d"}
set_2 = {"z","c","a","b","d","e"}
set_3 = set_1.issuperset(set_2)   # 使用函数实现
print(set_3)

# 打印内容如下:
False

frozenset(可迭代对象):返回一个冻结的集合.被冻结的集合不能进行修改,删除,添加等操作.如果不写参数,则返回一个冻结的空的集合.参数是可迭代对象所以可以是列表,字典等
下面是一些简单的事例:

set_1 = {"a","b","c","d"}
dic_1 = {"字典":""}
list_1 = [1,2,3]

set_2 = frozenset(set_1)
dic_2 = frozenset(dic_1)
list_2 = frozenset(list_1)

print(type(set_2),set_2)
print(type(dic_2),dic_2)   # 字典只能看键不能看值,很多方法都不能用
print(type(list_2),list_2) # 列表的下标也不能使用,大多数函数不能用

# 打印内容如下:
<class 'frozenset'> frozenset({'b', 'd', 'a', 'c'})
<class 'frozenset'> frozenset({'字典'})
<class 'frozenset'> frozenset({1, 2, 3})

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:网络编程协议(TCP和UDP协议,粘包问题)

下一篇:python模块之collections模块