python的容器类型

Posted 怿琴殇

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python的容器类型相关的知识,希望对你有一定的参考价值。

列表 list
可以存放任何数据类型

可变数据类型 vs 不可变数据类型
在原地址内存空间里,能修改内容的就是可变数据类型,不能修改内容的就不是可变数据类型

列表元素的增加操作                                    lst=[10,20,30]
append()(在列表末尾添加一个元素)                    lst.append(100)
extend() (在列表的末尾至少添加一个元素)      lst2=['hello','world']  lst.exted(lst2)
insert()  (在列表的任意位置添加一个元素)          lst.insert(1,90)
切片                    lst3=[Tru,False,'hello']  lst[1:]=lst3

切片例题:
lst3 = [print,None,1,'abd',True]
lst3
[<built-in function print>, None, 1, 'abd', True]
lst3 = [print,None,1,'abd',True]
lst3
[<built-in function print>, None, 1, 'abd', True]
lst3[::-2]
[True, 1, <built-in function print>]
lst3[::-1]
[True, 'abd', 1, None, <built-in function print>]
lst3[:-2]
[<built-in function print>, None, 1]


列表元素的删除操作                    lst=[10,20,30,40,50,60,30]
remove()(一次删除一个元素,重复元素删除第一个)    lst.remove(30)
pop()  (删除一个指定索引位置上的元素,不指定索引,删除列表最后一个元素)  lst.pop(1)   lst.pop()
切片  (一次至少删除一个元素)    new_lst=lst[1:3](产生一个新的列表)     lst[1:3]=[] (不产生新的列表对象,而是删除原列表中的内容)
clear()  (清空列表)         lst.clear()
del  (删除列表)             del lst


列表的排序操作    sort 进行排序       reverse 进行反转
lst=[20,40,10,98,54]
print('排序前的列表',lst)
lst.sort()     #升序排序
print('排序后的列表',lst)
lst.sort(reverse=True)      #表示降序排序
lst.sort(reverse=False)     #表示升序排序
new_lst=sorted(lst)

查找统计类:
copy复制拷贝    count出现多少次数   index出现的下标位置

例题:
有一条船,船上有40个人。船超载20个人,
每数到第九个就让他下船,最后输出哪些人下船了。
num = list(range(1,41))
while len(num) > 20:
    a = num[8]
    num = num[9:] + num[:8]
    print(f'a', end='#')

lst1 = [1,2,4,5,6]
for i in lst1:
    print(i)

成员关系运算符   (in)     (not in)
lst1 = [1,2,4,5,6]
if 67 in lst1:
    print('ok')
else:
    print('no')


enumerate()  可以返回数值和下标



# 从键盘接受用户输入,输入一个整数10,
# 返回两个数相加等于10这个数的下标 2,6
lst = [2,5,6,7,3,1,4]
i=0
sum = int(input('请输入一个整数:'))
for i in range(len(lst)):
    for j in range(i+1,len(lst)):
        if lst[i] + lst[j] == sum:
            print(f'lst[i]与lst[j]的和为sum,下标分别为i,j')

或者:
lst = [2,5,6,7,3,1,4]
num=int(input('请输入一个整数'))
for i,j in enumerate(lst):
    num1 = num - j
    if num1 in lst[i+1:] and lst.index(num1) > i :
        print(f"两数之和等于num的下标为i,lst.index(num1)")


元组(tuple)
有序的项目集合
可以存放任何数据类型
不可变数据类型

内建函数     工厂函数(类型转换)

#############元组的定义##############
只有一个元素,需要在元素后面加逗号
元组里面包含列表,列表是可以改变的,因为列表是可变数据类型,列表里的元素更改不会改变列表本身
不可变数据类型

例题:用户检测小工具
•欢迎语:”欢迎使用用户检测系统“
•定义一个用户列表,包含用户名密码:[('root', '123456'), ('admin', 'admin'),]
•键盘输入用户名、密码
•判断并验证用户密码,并给予相应提醒
lst=[('root','123456'),('admin','admin')]
print('欢迎使用用户检测系统')
u_name=input('请输入用户名')
u_passwd=input('请输入密码')
tup=(u_name,u_passwd)
if lst.count(tup) != 0:
    print('登陆成功')
else:
    print('用户名或密码错误')

Python 字典(Dictionary) items() 函数以列表返回可遍历的(键, 值) 元组数组

d = 'one': 1, 'two': 2, 'three': 3
>>> d.items()
dict_items([('one', 1), ('two', 2), ('three', 3)])
>>> type(d.items())
<class 'dict_items'>

字典( dict )
什么是字典( dict )
•字典是Python中一个键值映射的数据结构
•字典是无序的•字典是可变对象
•key必须是唯一的, so 天生去重

字典的定义
•元组通过花括号中用键 / 值对用冒号分割,而各个对用逗号分割

key必须是可hash对象
hash  是一类算法的统称,将任意长度的输入变成固定长度的输出
hash  是一项单向加密技术,可以通过原文得到hash值,但是不能通过hash去推导出原文
      常常用在验证文件的完成性,有没有被篡改,传输过程中有没有传完整

字典的原理
字典的本质就是一个空闲的hash表
以空间换时间

key必须是唯一的,而且必须是可hash对象
value可以使任何值

dict.get(key,default)   获取key的值,如果没有就返回default的值
                        如果没有default,不存在key的话就返回None

新增和修改
dict[key]=value

统计字符串中的每个字符出现的次数,不要重复输出
str1='hfisidjofhosif'
d1=
for i in str1:
    d1[i]=d1.get(i,0) + 1
print(d1)


删除
pop()
popitem()


d1 = 'a':1
d2 = 'b':2
dict(d1,**d2)  生成一个新字典
'a': 1, 'b': 2
d1.update(d2)   updata会覆盖
d1
'a': 1, 'b': 2


print('欢迎使用用户检测系统')
d1='root':'123456','admin':'admin'
while 1:
    u_name=input('请输入用户名')
    u_passwd=input('请输入密码')
    if u_name == 'q' or u_passwd == 'q':
        break
    if u_name in d1 and u_passwd == d1[u_name]:
        print('验证成功')
    else:
        print('验证失败')
print('慢走不送')


集合:
无序,不重复
可变的
看做一个只有key的字典
元素唯一,天生去重
可hash对象


.add()新增
.update()添加可迭代对象

例:
x = set('runoob')
>>> y = set('google')
>>> x, y
(set(['b', 'r', 'u', 'o', 'n']), set(['e', 'o', 'g', 'l']))   # 重复的被删除
>>> x & y         # 交集
set(['o'])
>>> x | y         # 并集
set(['b', 'e', 'g', 'l', 'o', 'n', 'r', 'u'])
>>> x - y         # 差集
set(['r', 'b', 'u', 'n'])
>>>

例如:
s1
1, 2, 3
s1.update('c':1,'b':3)
s1
1, 2, 3, 'c', 'b'
s1.add('asf')
s1
'asf', 1, 2, 3, 'c', 'b'
s1.update('c':1,'b':3.items())  #转换成元组
s1
'asf', 1, 2, 3, 'c', ('b', 3), ('c', 1), 'b'


remove()删除   如果删除的元素没有,会报错
discard()删除  不会报错

例如:
s1.remove(5)
Traceback (most recent call last):
  File "<input>", line 1, in <module>
KeyError: 5
s1.discard(5)


s1=1,2,3,4,5,6
s2=1,2,3,4,4,5,6,7,3
s1&s2                    #取交集
1, 2, 3, 4, 5, 6
s1|s2                    #取或,都存在的,并集
1, 2, 3, 4, 5, 6, 7
s1 -s2                   #在s1里取s2没有的
set()
s2 -s1                   #在s2里取s1没有的
7
s1 ^ s2                  #并集减去交集,对称差集
7

以上是关于python的容器类型的主要内容,如果未能解决你的问题,请参考以下文章

尝试将片段添加到我的片段容器 FrameLayout

13 个非常有用的 Python 代码片段

[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础

在python 3.6中处理自定义编码时遇到类型错误

Python基础12_Python中的容器类型公共方法

Python学习总结