【python】-- 元组、字典

时间:2023-03-09 19:05:22
【python】-- 元组、字典

元组

元组其实跟列表差不多,也是存一组数,只不是它一旦创建,便不能再修改,所以又叫只读列表

用途:一般情况下用于自己写的程序能存下数据,但是又希望这些数据不会被改变,比如:数据库连接信息等

1.访问元祖

 >>> name = ('a','b','c','d')
#下标值跟列表一样,也是从0开始
>>> name[0]
'a'
>>> name[1]
'b'
#访问最后一个元素
>>> name[-1]
'd'

2,count(统计) 与 index(索引)

# count 统计元素数量
name = ('a','b','c','a')
name.count('a') # # index 查看元素下标
name = ('a','b','c','a')
name.index('b')#

3、修改元组 删除元祖

#元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下实例:
tup1 = (12, 34.56);
tup2 = ('abc', 'xyz') # 以下修改元组元素操作是非法的。
# tup1[0] = 100 # 创建一个新的元组
tup3 = tup1 + tup2;
print (tup3) #(12, 34.56, 'abc', 'xyz') #元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组,如下实例:
#!/usr/bin/python3 tup = ('Google', 'Runoob', 1997, 2000) print (tup)
del tup;
print ("删除后的元组 tup : ")
print (tup) # NameError: name 'tup' is not defined

小结:

①元组中的数据不可以被修改,不可以被添加,不可以被删除(当然除非是元组中嵌套列表或者字典,列表和字典中的值是可以被更改的)

②元组的获取元素的方式和列表一样,都是通过下标值访问,下标值都是从0开始

③由于元组只能读,不能写,所以元组只有count和index两个方法

④元组的切片功能和列表一样

字典

字典是另一种可变容器模型,且可存储任意类型对象。

字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }

一、特征:

字典值可以没有限制地取任何python对象,既可以是标准的对象,也可以是用户定义的,但键不行

1、字典是无序的;

2,字典的key是唯一的,不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住,如下实例:

dict = {'Name': 'QQ', 'Age': 7, 'Name': 'DD'}

print ("dict['Name']: ", dict['Name']) # DD

3、键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行,如下实例:

dict = {['Name']: 'Runoob', 'Age': 7}

print ("dict['Name']: ", dict['Name']) # TypeError: unhashable type: 'list'

二、基本用法:增加、查看、修改、删除

1、增加

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#新增
>>> stu_info["wanger"] = 30
#输出结果
>>> stu_info
{'wanger': 30, 'lisi': 18, 'zhangsan': 23, 'qigao': 18}

2、修改

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#修改'qigao'对应的value值,由18改为23
>>> stu_info["qigao"] = 23
#输出
>>> stu_info
{'wanger': 30, 'lisi': 18, 'zhangsan': 23, 'qigao': 23}

3、删除(del、pop、popitem)

del

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
>>> del stu_info['qigao']
#结果输出
>>> stu_info
{'zhangsan': 23, 'lisi': 18}

注:如果是del stu_info的话,则是删除stu_info这个变量

pop

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#删除时给出提示
>>> stu_info.pop("qigao")
18
#输出结果
>>> stu_info
{'zhangsan': 23, 'lisi': 18}

popitem

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#随机删除的元素
>>> stu_info.popitem()
('lisi', 18)
#输出结果
>>> stu_info
{'zhangsan': 23, 'qigao': 18}

4、查

通过key查找value

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#存在key返回value
>>> stu_info["qigao"]
18
#不存在key提示报错
>>> stu_info["wanger"]
Traceback (most recent call last):
File "<input>", line 1, in <module>
KeyError: 'wanger'

通过get(key) 查找value

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
#存在则返回对应的value
>>> print(stu_info.get("qigao"))
18
#不存在返回None
>>> print(stu_info.get("wanger"))
None

注:get(k)不存在key值,则返回None,通过key直接访问会报错,所以建议推荐用get(k)这个方法获取value

通过key in 字典判断  key是否存在与字典中

>>> stu_info = {"zhangsan":23,"lisi":18,"qigao":18}
>>> "qigao" in stu_info #标准用法,在Python3和Python2.7都可以用
True

5、多级字典嵌套及操作

av_catalog = {
"欧美":{
"www.youporn.com": ["很多免费的,世界最大的","质量一般"],
"www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
"x-art.com":["质量很高,真的很高","全部收费,屌比请绕过"]
},
"日韩":{
"tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","听说是收费的"]
},
"大陆":{
"":["全部免费,真好,好人一生平安","服务器在国外,慢"]
}
} av_catalog["大陆"][""][1] += ",可以用爬虫爬下来"
print(av_catalog["大陆"][""])
#ouput
['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫爬下来']

三、字典的内置方法:

#clear()  删除字典内所有元素
dict = {'Name': 'Zara', 'Age': 7} print ("字典长度 : %d" % len(dict))
dict.clear()
print ("字典删除后长度 : %d" % len(dict)) #字典长度 : 2
#字典删除后长度 : 0 #-------------------------------------------------------------------- #copy() 返回一个字典的浅复制
dict1 = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} dict2 = dict1.copy()
print ("新复制的字典为 : ",dict2) #新复制的字典为 : {'Age': 7, 'Name': 'Runoob', 'Class': 'First'} #--------------------------------------------------------------------
# fromkeys() 函数用于创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值 seq = ('name', 'age', 'sex') dict = dict.fromkeys(seq)
print ("新的字典为 : %s" % str(dict)) dict = dict.fromkeys(seq, 10)
print ("新的字典为 : %s" % str(dict))
#新的字典为 : {'age': None, 'name': None, 'sex': None}
#新的字典为 : {'age': 10, 'name': 10, 'sex': 10} #--------------------------------------------------------------------
#get() 函数返回指定键的值,如果值不在字典中返回默认值。
dict = {'Name': 'Runoob', 'Age': 27} print ("Age 值为 : %s" % dict.get('Age'))
print ("Sex 值为 : %s" % dict.get('Sex', "NA")) #Age 值为 : 27
#Sex 值为 : NA #--------------------------------------------------------------------
# items() 方法以列表返回可遍历的(键, 值) 元组数组。
dict = {'Name': 'Runoob', 'Age': 7} print ("Value : %s" % dict.items())
#Value : dict_items([('Age', 7), ('Name', 'Runoob')]) #-------------------------------------------------------------------- keys(), values()方法以列表返回一个字典所有的键,值
dict = {'Name': 'QQ', 'Age': 7} print ("字典所有的键为 : %s" % dict.keys())
print ("字典所有值为 : ", list(dict.values()))
#字典所有的键为 : dict_keys(['Age', 'Name'])
#"字典所有值为 : ", ["QQ","7"] #--------------------------------------------------------------------
#setdefault() 方法和get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值
dict = {'Name': 'Runoob', 'Age': 7} print ("Age 键的值为 : %s" % dict.setdefault('Age', None))
print ("Sex 键的值为 : %s" % dict.setdefault('Sex', None))
print ("新字典为:", dict)
#Age 键的值为 : 7
#Sex 键的值为 : None
#新字典为: {'Age': 7, 'Name': 'Runoob', 'Sex': None} #--------------------------------------------------------------------
#update() 函数把字典dict2的键/值对更新到dict里。
dict = {'Name': 'Runoob', 'Age': 7}
dict2 = {'Sex': 'female' } dict.update(dict2)
print ("更新字典 dict : ", dict)
#更新字典 dict : {'Sex': 'female', 'Age': 7, 'Name': 'Runoob'}

四、循环字典

方法1:

 for key in dict:
print(key,dict[key])

方法2:

 for k,v in info.items(): #会先把dict转成list,数据量大时莫用
print(k,v)

注:

①方法1的效率比方法2的效率高很多

②方法1是直接通过key取value

③方法2是先把字典转换成一个列表,再去取值

④当数据量比较大的时候,用第二种方法时,字典转换成列表的这个过程需要花大量的时间老转换,当然数据量不大,没有关系,效率差不多