python_4
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的更多相关文章
- [Python_4] Python 面向对象(OOP)
0. 说明 Python 面向对象(OOP) 笔记.迭代磁盘文件.析构函数.内置方法.多重继承.异常处理 参考 Python面向对象 1. 面向对象 # -*-coding:utf-8-*- &quo ...
- python_4程序设计基础
1注释 2变量和常量 3命名 4表达式 5赋值语句
- python_函数嵌套(4)
第1章 名称空间 1.1 定义 1.2 变量运行流程 1.3 临时名称空间 1.4 python三种名称空间 第2章 作用域 2.1 作用域分类 2.2 加载顺序 2.3 取值顺序 函数嵌套 2.4 ...
随机推荐
- 记校赛水题----AK爷兼职计
Description AK爷最近收到一份兼职,是去幼儿园看小朋友,AK爷认为看孩子这件事情很简单,但是事实并非如此.幼儿园里的孩子们喜欢数学,不仅九九乘法口诀倒背如流而且精通各种算法.某天,AK爷上 ...
- 提升Python编程效率的几种方法
前言 我们知道Python这门语言在运行速度上已经败给了许多别的语言(比如C, C++, Java, Golang....).但从一个开发者的角度来看Python是我最喜欢的语言,很大一部分原因在于其 ...
- git 一些操作
1. 代码相关 克隆代码 git clone xxx.git 拉取代码 git pull 查看 修改的 状态 git status 推送代码 git push add 或者 修改代码之后 回滚到 未修 ...
- Java 使用控制台操作实现数据库的增删改查
使用控制台进行数据库增删改查操作,首先创建一个Java Bean类,实现基础数据的构造,Get,Set方法的实现,减少代码重复性. 基本属性为 学生学号 Id, 学生姓名 Name,学生性别 Sex, ...
- 解决XML警告"No grammar constraints (DTD or XML Schema) referenced in the document"
解决办法: 顶部有这两行信息即可解决警告: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ...
- kafka 零拷贝
kafka通过零拷贝实现高效的数据传输 https://blog.csdn.net/lxlmycsdnfree/article/details/78973864 Kafka零拷贝 https://bl ...
- 2020/1/28 PHP代码审计之命令执行漏洞
0x00 命令执行漏洞原理 应用程序有时需要调用一些执行系统命令的函数,如在PHP中,使用system.exec.shell_exec.passthru.popen.proc_popen等函数可以执行 ...
- Vue.js——1.初识Vue
初识Vue.js 1. 什么是Vue.js Vue.js是前端主流框架之一,现在看招聘几乎都要求会vue 好像成了前端的代名词. Vue.js是构建界面 只关注视图层V,也就是页面的, 2. 为什么要 ...
- 使用idea出现的错误
错误:打开maven项目时出现"程序包 com.sun.org.apache.xpath.internal 不可见 "的错误 这个问题出现的原因是: jdk版本的问题.可能是因为有 ...
- Bezier曲线的实现——de Casteljau算法
这学期同时上了计算机图形学和计算方法两门课,学到这部分的时候突然觉得de Casteljau递推算法特别像牛顿插值,尤其递推计算步骤很像牛顿差商表. 一开始用伯恩斯坦多项式计算Bezier曲线的时候, ...