[Python笔记04] 自定义序列类

1.序列类型的分类

在这里插入图片描述

2.序列的+、+=、extend和append的区别

# + 
a = [1, 2]
c = a + [3, 4]	#需要赋值给一个变量
print(c)

# +=
a += [3,4]	#相当于a = a + [3, 4]
print(a)

a = [1, 2]
a += (3, 4)	#可以相加元组
print(a)

# extend
a = [1, 2]
a.extend([0, 1, 2])  #迭代放入列表
print(a)

# append
a = [1, 2]
a.append([0, 1, 2]) #直接放入列表
print(a)

输出结果

[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 0, 1, 2]
[1, 2, [0, 1, 2]]

3.实现可切片的对象

(1)列表切片操作

#模式[start:end:step]
"""
    其中,第一个数字start表示切片开始位置,默认为0;
    第二个数字end表示切片截止(但不包含)位置(默认为列表长度);
    第三个数字step表示切片的步长(默认为1)。
    当start为0时可以省略,当end为列表长度时可以省略,
    当step为1时可以省略,并且省略步长时可以同时省略最后一个冒号。
    另外,当step为负整数时,表示反向切片,这时start应该比end的值要大才行。
"""
aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]

print(aList[::])  # 返回包含原列表中所有元素的新列表
#输出:[3, 4, 5, 6, 7, 9, 11, 13, 15, 17]

print(aList[::-1])  # 返回包含原列表中所有元素的逆序列表
#输出:[17, 15, 13, 11, 9, 7, 6, 5, 4, 3]

print(aList[::2])  # 隔一个取一个,获取偶数位置的元素
#输出:[3, 5, 7, 11, 15]

print(aList[1::2])  # 隔一个取一个,获取奇数位置的元素
#输出:[4, 6, 9, 13, 17]

print(aList[3:6])  # 指定切片的开始和结束位置
#输出:[6, 7, 9]

print(aList[0:100])  # 切片结束位置大于列表长度时,从列表尾部截断
#输出:[3, 4, 5, 6, 7, 9, 11, 13, 15, 17]

print(aList[100:])  # 切片开始位置大于列表长度时,返回空列表
#输出:[]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[len(aList):] = [9]  # 在列表尾部增加元素
print(aList)
#输出:[3, 4, 5, 6, 7, 9, 11, 13, 15, 17, 9]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[:0] = [1, 2]  # 在列表头部插入元素
print(aList)
#输出:[1, 2, 3, 4, 5, 6, 7, 9, 11, 13, 15, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[3:3] = [4]  # 在列表中间位置插入元素
print(aList)
#输出:[3, 4, 5, 4, 6, 7, 9, 11, 13, 15, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[:3] = [1, 2]  # 替换列表元素,等号两边的列表长度相等
print(aList)
#输出:[1, 2, 6, 7, 9, 11, 13, 15, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[3:] = [4, 5, 6]  # 等号两边的列表长度也可以不相等
print(aList)
#输出:[3, 4, 5, 4, 5, 6]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[::2] = [0] * 5  # 隔一个修改一个
print(aList)
#输出:[0, 4, 0, 6, 0, 9, 0, 13, 0, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
aList[::2] = ['a', 'b', 'c', 'd', 'e']  # 隔一个修改一个
print(aList)
#输出:['a', 4, 'b', 6, 'c', 9, 'd', 13, 'e', 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
#aList[::2] = [1,2]  # 左侧切片不连续,等号两边列表长度必须相等
aList[:3] = []  # 删除列表中前3个元素
print(aList)
#输出:[6, 7, 9, 11, 13, 15, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
del aList[:3]  # 切片元素连续
print(aList)
#输出:[6, 7, 9, 11, 13, 15, 17]

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]
del aList[::2]  # 切片元素不连续,隔一个删一个
print(aList)
#输出:[4, 6, 9, 13, 17]

(2)模拟实现一个可迭代序列

import numbers
class Group:
    #支持切片操作
    def __init__(self, group_name, company_name, staffs):
        self.group_name = group_name
        self.company_name = company_name
        self.staffs = staffs
    
    '''反转列表功能'''
    def __reversed__(self):
        self.staffs.reverse()
    
    '''获取元素'''
    def __getitem__(self, item):
        cls = type(self)
        if isinstance(item, slice): #如果传入的是切片,返回切片数据
            return cls(group_name=self.group_name, company_name=self.company_name, staffs=self.staffs[item])
        elif isinstance(item, numbers.Integral):    #如果传入的是数字,返回对应的元素
            print([self.staffs[item]])  #打印获取到的元素
            return cls(group_name=self.group_name, company_name=self.company_name, staffs=[self.staffs[item]])
    
    '''计算长度'''
    def __len__(self):
        return len(self.staffs)
    
    '''实现迭代'''
    def __iter__(self):
        return iter(self.staffs)
    
    '''判断元素是否存在集合中'''
    def __contains__(self, item):
        if item in self.staffs:
            return True
        else:
            return False
    
staffs = ["bobby1", "bobby2", "bobby3", "bobby4"]
group = Group(company_name="tencent", group_name="user", staffs=staffs)
print(len(group))
print(group[1])
reversed(group)
for user in group[:2]:
    print(user)

if "bobby1" in group:
    print("yes")

输出结果

4
['bobby2']
<__main__.Group object at 0x0000028BC9DF09B0>
bobby4
bobby3
yes

4.bisect管理已排序序列

import bisect
from collections import deque

#用来处理已排序的序列,用来维持已排序的序列,升序
#二分查找
inter_list = deque()
bisect.insort(inter_list, 3)
bisect.insort(inter_list, 2)
bisect.insort(inter_list, 5)
bisect.insort(inter_list, 1)
bisect.insort(inter_list, 6)
bisect.insort(inter_list, 5)


print(inter_list)

print(bisect.bisect_left(inter_list, 5))    #找到第一个元素5,在左边插入的位置

print(bisect.bisect_right(inter_list, 5))   #找到最后一个元素5,在右边插入的位置

输出结果

deque([1, 2, 3, 5, 5, 6])
3
5

5.列表、字典、集合推导式

#列表推导式
int_list = [1, 2, 3, 4, 5]
qu_list = [item * item for item in int_list]
print(type(qu_list))
print(qu_list)
#输出:
#<class 'list'>
#[1, 4, 9, 16, 25]


#逻辑复杂的情况
int_list = [1, 2, -3, 4, 5]
qu_list = [item if item > 0 else abs(item) for item in int_list]
print(qu_list)
#输出:
#[1, 2, 3, 4, 5]


#笛卡尔积
int_list1 = [1, 2]
int_list2 = [3, 4]

qu_list = [(first, second) for first in int_list1 for second in int_list2]
print(qu_list)
#输出:
#[(1, 3), (1, 4), (2, 3), (2, 4)]


#生成器表达式
odd_gen = (i for i in range(21) if i % 2 == 1)
print(type(odd_gen))
for i in odd_gen:
    print(i, end=" ")
#输出:
#<class 'generator'>
#1 3 5 7 9 11 13 15 17 19 


#转换为列表
odd_gen = (i for i in range(21) if i % 2 == 1)
odd_list = list(odd_gen)
print(type(odd_list))
print(odd_list)
#输出:
#<class 'list'>
#[1, 3, 5, 7, 9, 11, 13, 15, 17, 19]


#字典推导式
my_dict = {"bobby1":22, "bobby2":23, "bobby3":5}
reversed_dict = {value:key for key, value in my_dict.items()}
print(reversed_dict)
#输出:
#{22: 'bobby1', 23: 'bobby2', 5: 'bobby3'}


#集合推导式
my_set = {key for key, value in my_dict.items()}
print(type(my_set))
print(my_set)
#输出:
#<class 'set'>
#{'bobby1', 'bobby2', 'bobby3'}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值