Python高级编程和异步IO并发编程---学习笔记--- 第五章---自定义序列类

每日提醒ctrl+鼠标左键可以查看源码

 

5-1 python中的序列分类

容器序列:放置任意类型

5-2 python中序列类型的abc继承关系

实操,演示

5-3 list中extend方法区别.

+号左右两边数据类型一致,产生新对象
+=就地改变,不产生新对象
append加进去一个整体
extend添加时会对被添加对象进行for循环

my_list = []
my_list.append(1)
my_list.append("a")

from collections import abc

a = [1,2]
c = a + [3,4]

#就地加
# a += (3,4)
# 
# a.extend(range(3))

a.append((1,2))
print(a)

5-4 实现可切片的对象

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[::])  # 返回包含原列表中所有元素的新列表
print (aList[::-1])  # 返回包含原列表中所有元素的逆序列表
print (aList[::2])  # 隔一个取一个,获取偶数位置的元素
print (aList[1::2])  # 隔一个取一个,获取奇数位置的元素
print (aList[3:6])  # 指定切片的开始和结束位置
aList[0:100]  # 切片结束位置大于列表长度时,从列表尾部截断
aList[100:]  # 切片开始位置大于列表长度时,返回空列表

aList[len(aList):] = [9]  # 在列表尾部增加元素
aList[:0] = [1, 2]  # 在列表头部插入元素
aList[3:3] = [4]  # 在列表中间位置插入元素
aList[:3] = [1, 2]  # 替换列表元素,等号两边的列表长度相等
aList[3:] = [4, 5, 6]  # 等号两边的列表长度也可以不相等
aList[::2] = [0] * 3  # 隔一个修改一个
print (aList)
aList[::2] = ['a', 'b', 'c']  # 隔一个修改一个
aList[::2] = [1,2]  # 左侧切片不连续,等号两边列表长度必须相等
aList[:3] = []  # 删除列表中前3个元素

实现可切片对象(重写魔法函数,再次实例化)

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):
            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)
    #实现使用if in判断
    def __contains__(self, item):
        if item in self.staffs:
            return True
        else:
            return False

staffs = ["bobby1", "imooc", "bobby2", "bobby3"]
group = Group(company_name="imooc", group_name="user", staffs=staffs)
reversed(group)
for user in group:
    print(user)

5-5 bisect维护已排序序列

自动排序列表,还可以查询插入元素所对应的位置,已有的元素返回索引(左插)或索引+1(右插),新元素在列表最后插入,因此返回的索引是

len(list)+1

mport 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)

print(bisect.bisect_right(inter_list, 3))
#学习成绩
print(inter_list)

5-6 什么时候我们不该使用列表

pycharm:crtl+鼠标左键查看内置方法,可以使用structure 查看结构,数据类型一致时使用array等会更高效

# array, deque
# 数组
import array
#array和list的一个重要区别, array只能存放指定的数据类型
my_array = array.array("i")
my_array.append(1)
my_array.append("abc")

5-7 列表推导式、生成器表达式、字典推导式

 list1=[i for i in range(19) if i %2==0]
# print(list1)

#1列表推导式(生成式)
#实现偶数求平方,只有if放循环后面
#列表生成式的性能高于列表操作,if else结构放循环前面
def handle(item):
    return item*item
list1=[handle(i) for i in range(19) if i %2==0]
print(list1)


int_list = [1,2,-3,4,5]
qu_list = [item  if item > 0 else abs(item) for item in int_list ]
print(qu_list)

#2生成器表达式
int_list = [1,2,-3,4,5]
gen_list = (item  if item > 0 else abs(item) for item in int_list )
print(gen_list)
for _ in gen_list:
    print(_)

#3字典推导式
dict={"key1":"value1","key2":"value2","key3":"value3"}
reversed_dict={value:key for key,value in dict.items()}
print(reversed_dict)

#4集合推导式
dict={"key1":"value1","key2":"value2","key3":"value3"}
#第一种方式
my_set=set(dict.keys())
#第二种方式,更灵活
my_set1={value for key,value in dict.items()}
print(my_set)
print(my_set1)

5-8 本章小结

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值