1.迭代器:通过iter()方法获得了list的迭代对象,然后就可以通过next()方法来访问list中的元素了,当容器中没有可访问元素时,会抛出StopIteration异常终止迭代器

data = [1,2,3,4,5]
itr = iter(data)
print(itr.__next__())

2.自定义迭代器:需要实现__iter__,__next__方法

class CustomRange:
def _init__(self, length):
self.inx = 0
self.length = length
def __iter__(self):
return self
def __next__(self):
if self.inx < self.length:
val = self.idx
self.idx += 2
return val
else:
raise StopIteration if __name__ == "__main__":
cr = CustomRange(20)
print(next(cr))
print(next(cr))

3.生成器,yield

4.生成器与迭代器的区别:

> 通过实现迭代器协议对应的__iter__()和__next__()方法,可以自定义迭代器。对于可迭代对象,for语句可以通过iter()方法获取迭代器,并且通过next方法获取容器的下一个元素

> 生成器是一种特殊的迭代器,内部支持了生成器协议,不需要明确定义__iter__()和__next__()方法

> 生成器通过生成器函数产生,生成器函数可以通过常规的def来定义,但是不用return返回,而是用yield一次返回一个结果

5.列表的api

# append,在后方插入一个元素
# insert(index, obj),插入一个元素
# pop(index),默认移除最后一个元素
# remove(obj),移除第一个匹配的元素,一次删除一个
# index(obj),找到第一个匹配到的元素的索引,没有则抛异常
# count(obj),统计匹配到的元素的次数
# extend(seq),在列表末尾追加序列中的元素
# reverse(),列表反转
# sort([Func]),排序,根据ASCII码从大到小进行排
ll = [(1,5,4),(1,2,3,6,3),(5,1,4,3)]
# 按照每个元素的长度大小进行排序
ll.sort(key=lambda x: len(x), reverse=True)

6.复制

# 引用复制
a = [1,2,3]
b = a
# 非引用复制
a = [1,2,3]
b = a[:]
# copy,deepcopy
a = [1,2,['a', 'b']]
b = a #将a的引用给b,无论a如何变化,b都将保持跟随,因为a,b指向的是同一个
c = copy.copy(a) # 浅拷贝,只拷贝父对象,不会拷贝父对象中的子对象,对子对象拷贝的仍然是子对象的引用。即:a.append(6),c不会变化,如果a[2].append("c"),c会变化。c中的子对象会跟随a中的子对象进行变化。
d = copy.deepcopy(a) # 深拷贝,与a完全没有任何瓜葛了

7.列表推导

ret = [ i for i in [1,2,3] if i >2]

8.枚举

for inx, value in enumerate([11,22,33]):
print inx, value

9.使用list实现一个栈

# 使用list实现栈
# coding:utf-8 class Stack:     """
    栈
    """
    _arr = []
    capcity = 0
    size = 0
    def __init__(self, capcity=100):
        self.capcity = capcity     def push(self, element):
        if self.is_full:
            raise Exception("The Stack is FULL")
        self._arr.append(element)
        self.size += 1     def pop(self):
        if not self.is_empty:
            del self._arr[self.size - 1]
            self.size -= 1
        else:
            raise Exception("The Stack is EMPTY")     def is_empty(self):
        if self.size == 0:
            return True
        return False     @property
    def foo(self):
        return self._foo     @property
    def is_full(self):
        if self.size >= self.capcity:
            return True
        return False     def get_stack(self):
        if not self.is_empty:
            return self._arr[self.size - 1]
        raise Exception("The stack is EMPTY")     def __str__(self):
        msg = ["Stack: "]
        if self.is_empty:
            return "Stack is EMPTY!"
        for arr in self._arr:
            msg.append(str(arr) + " ")
        return "".join(msg)

10.字典排序

d = {3:3,8:-9,1:1,0:0}
s = sorted(d.items(), key=lambda x:x[1], reverse=False)

> dict.fromkeys(seq)

> dict.fromkeys(seq, 0)

> d.get("1", "key not found") #防治抛出异常

> d.update({111:111}),如果有这个key,就更新value,没有则添加到d中

9

 

python_4的更多相关文章

  1. [Python_4] Python 面向对象(OOP)

    0. 说明 Python 面向对象(OOP) 笔记.迭代磁盘文件.析构函数.内置方法.多重继承.异常处理 参考 Python面向对象 1. 面向对象 # -*-coding:utf-8-*- &quo ...

  2. python_4程序设计基础

    1注释 2变量和常量 3命名 4表达式 5赋值语句

  3. python_函数嵌套(4)

    第1章 名称空间 1.1 定义 1.2 变量运行流程 1.3 临时名称空间 1.4 python三种名称空间 第2章 作用域 2.1 作用域分类 2.2 加载顺序 2.3 取值顺序 函数嵌套 2.4 ...

随机推荐

  1. MySQL授权用户登录访问指定数据库

    使用Navicat等客户端工具,选中需要共享的数据库,点击查询>新建查询 1.写SQL语句:GRANT ALL PRIVILEGES ON * TO 'test'@'%'IDENTIFIED B ...

  2. OGG实验:喂奶间隔数据表通过OGG配置同步

    我之前在<使用SQL计算宝宝每次吃奶的时间间隔(数据保障篇)>中提到数据实时同步的方案,其中有一种是数据表通过OGG进行同步,当时没有详细展开测试,只给了之前学习OGG时的配置示例.由于之 ...

  3. Python Scrapy的QQ音乐爬虫 音乐下载、爬取歌曲信息、歌词、精彩评论

    QQ音乐爬虫(with scrapy)/QQ Music Spider UPDATE 2019.12.23 已实现对QQ音乐文件的下载,出于版权考虑,不对此部分代码进行公开.此项目仅作为学习交流使用, ...

  4. 随机森林RF

    bagging 随机森林顾名思义,是用随机的方式建立一个森林,森林里面有很多的决策树组成,随机森林的每一棵决策树之间是没有关联的.在得到森林之后,当有一个新的输 入样本进入的时候,就让森林中的每一棵决 ...

  5. mybatis-地区三表生成地区树

    package com.dhht.manager.vo.area; import lombok.Data; import java.io.Serializable;import java.util.L ...

  6. idea抛出异常:org.apache.shiro.authc.AuthenticationException

    问题描述 继续在ubuntu下折腾,终于将web项目的所有的东西配置好了,然后运行项目,满怀期待的心情登录系统的时候,突然出现了这个bug,吓得我差点从椅子上跳起来,这两天遇到的bug实在是太多了.. ...

  7. OpenMP笔记(二)

    原文:https://www.bearoom.xyz/2019/02/18/openmp2/ OpenMP是由三部分组成的:指令.库函数和环境变量. 一.指令 在C/C++中使用OpenMP需要用到的 ...

  8. ICRA 2019最佳论文公布 李飞飞组的研究《Making Sense of Vision and Touch: Self-Supervised Learning of Multimodal Representations for Contact-Rich Tasks》获得了最佳论文

    机器人领域顶级会议 ICRA 2019 正在加拿大蒙特利尔举行(当地时间 5 月 20 日-24 日),刚刚大会公布了最佳论文奖项,来自斯坦福大学李飞飞组的研究<Making Sense of ...

  9. 19 docker 多机器通信

    1. 本章实验 2. 环境搭建 1.编写 Vagrantfile 并创建虚拟机 并虚拟机node1绑定外部 192.168.205.10:8888 node2绑定外部 192.168.205.10:9 ...

  10. Spring Cloud Alibaba 教程 | Nacos(六)

    集群模式部署 前面我们已经学习了Nacos作为注册中心.配置中心的相关功能,但是我们之前启动Nacos是通过单实例模式启动的,只适合在学习和开发阶段,生产环境需要保证Nacos的高可用,所以今天我们来 ...