写在前面:本文主要是python高级练习部分,介绍了一些高级用法,这些都是零散的小知识,这些可以与函数式编程合在一起使用。

函数式编程[1]:Python中提供的函数式编程主要有:

  • map(函数,可迭代式)映射函数
  • filter(函数,可迭代式)过滤函数
  • reduce(函数,可迭代式)规约函数
  • lambda函数
  • 列表推导式
  • zip()函数

generator 生成

词汇

generator 英[ˈdʒenəreɪtə(r)] 美[ˈdʒɛnəˌretɚ]

n. 发电机,发生器; 电力公司; 生产者,创始者; [乐] 基础低音

My understanding

关于生成器的基本概念,我没有详述,因为有关它的描述,网上一搜,一大把,在我看来,学习最有效的方法就是自己运行案例,通过案例反映生成器的作用。

比如,【点这里】,哈哈这也是总结的。

案例1:元组推导式自动生成 generator

s = (x * x for x in range(5))
print(s)
<generator object <genexpr> at 0x000001343C239F10>
for x in s:
print(x, end=',')
0,1,4,9,16,

案例2:Fibonacci sequence

【原理,点我】

def fib(maximum):
n, a, b = 0, 0, 1
while n < maximum:
yield b
a, b = b, a+b
n += 1
return 'done' f = fib(10)
print('fib(10)', f)
fib(10) <generator object fib at 0x000001343C239E08>
for x in f:
print(x, end=' ')
1 1 2 3 5 8 13 21 34 55
g = fib(5)
while 1:
try:
x = next(g)
print('g:', x)
except StopIteration as e:
print('Generator return value:', e.value)
break
g: 1
g: 1
g: 2
g: 3
g: 5
Generator return value: done

iter 迭代

其实,迭代有可迭代的迭代器,一个是形容词,一个是名词,所以他们是与区别的。

如果要使用需要导入from collections import Iterable, Iterator

案例1:可迭代的

from collections import Iterable, Iterator

def g():
yield 1
yield 2
yield 3 print('Iterable? [1, 2, 3]:', isinstance([1, 2, 3], Iterable))
print('Iterable? \'abc\':', isinstance('abc', Iterable))
print('Iterable? 123:', isinstance(123, Iterable))
print('Iterable? g():', isinstance(g(), Iterable))
Iterable? [1, 2, 3]: True
Iterable? 'abc': True
Iterable? 123: False
Iterable? g(): True

综上:

  1. 列表是可迭代的
  2. 字符串是可迭代的
  3. 数字是不可迭代的的
  4. 自定义的g()函数是可迭代的

案例2:迭代器

如果我们使用iter()函数作用,可将列表and元组转化为迭代器。

print('Iterator? [1, 2, 3]:', isinstance([1, 2, 3], Iterator))
print('Iterator? iter([1, 2, 3]):', isinstance(iter([1, 2, 3]), Iterator))
print('Iterator? \'abc\':', isinstance('abc', Iterator))
print('Iterator? 123:', isinstance(123, Iterator))
print('Iterator? g():', isinstance(g(), Iterator))
print('Iterator? (1, 2, 3):', isinstance((1, 2, 3), Iterator))
print('Iterator? iter((1, 2, 3)):', isinstance(iter((1, 2, 3)), Iterator))
Iterator? [1, 2, 3]: False
Iterator? iter([1, 2, 3]): True
Iterator? 'abc': False
Iterator? 123: False
Iterator? g(): True
Iterator? (1, 2, 3): False
Iterator? iter((1, 2, 3)): True

综上:

  1. 列表 not is 迭代器
  2. 采用iter()转化的列表 is 迭代器
  3. 字符串not is 迭代器
  4. 数字not is 迭代器
  5. 自定义的g()函数is 迭代器
  6. 元组 not is 迭代器
  7. 采用iter()转化的元组 is 迭代器

案例3:迭代元素

例子1

print('for x in [1, 2, 3, 4, 5]:')
for x in [1, 2, 3, 4, 5]:
print(x)
for x in [1, 2, 3, 4, 5]:
1
2
3
4
5

例子2

print('for x in iter([1, 2, 3, 4, 5]):')
for x in iter([1, 2, 3, 4, 5]):
print(x)
for x in iter([1, 2, 3, 4, 5]):
1
2
3
4
5

例子3

print('next():')
it = iter([1, 2, 3, 4, 5])
print(next(it))
print(next(it))
print(next(it))
print(next(it))
print(next(it))
next():
1
2
3
4
5

案例4:字典迭代

想知道,字典的情况【点我】

构造字典

key = 'a', 'b', 'c'
value = 1, 2, 3
d = dict(zip(key, value))

迭代字典的键

print('iter key:', d)
for k in d.keys():
print('key:', k)
iter key: {'a': 1, 'b': 2, 'c': 3}
key: a
key: b
key: c

迭代字典的值

print('iter value:', d)
for v in d.values():
print('value:', v)
iter value: {'a': 1, 'b': 2, 'c': 3}
value: 1
value: 2
value: 3

迭代字典的键值对

print('iter item:', d)
for k, v in d.items():
print('item:', k, v)
iter item: {'a': 1, 'b': 2, 'c': 3}
item: a 1
item: b 2
item: c 3

列表迭代与推导

列表操作原理,【点我】

列表迭代

for i, value in enumerate(['A', 'B', 'C']):
print(i, value)
0 A
1 B
2 C
for x, y in [(1, 1), (2, 4), (3, 9)]:
print(x, y)
1 1
2 4
3 9

列表推导式

print([x*x for x in range(1, 11)])
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
print([x*x for x in range(1, 11) if x%2 == 0])
[4, 16, 36, 64, 100]
print([m + n for m in 'ABC' for n in 'XYZ'])
['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
d = {'x':'A', 'y':'B', 'z':'C'}
print([k + '=' + v for k, v in d.items()])
['x=A', 'y=B', 'z=C']
L = ['Hello', 'World', 'Apple', 'IBM']
print([s.lower() for s in L])
['hello', 'world', 'apple', 'ibm']

切片

L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack']
for i, value in enumerate(L):
print("L列表中元素的序:{}-->{}-->{}".format(i, value, i-len(L)))
L列表中元素的序:0-->Michael-->-5
L列表中元素的序:1-->Sarah-->-4
L列表中元素的序:2-->Tracy-->-3
L列表中元素的序:3-->Bob-->-2
L列表中元素的序:4-->Jack-->-1
print('L[0:3] =', L[0:3])
print('L[:3] =', L[:3])
print('L[1:3] =', L[1:3])
print('L[-2:] =', L[-2:])
L[0:3] = ['Michael', 'Sarah', 'Tracy']
L[:3] = ['Michael', 'Sarah', 'Tracy']
L[1:3] = ['Sarah', 'Tracy']
L[-2:] = ['Bob', 'Jack']
R = list(range(100))
print('R[:10] =', R[:10])
print('R[-10:] =', R[-10:])
print('R[10:20] =', R[10:20])
print('R[:10:2] =', R[:10:2])
print('R[::5] =', R[::5])
R[:10] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
R[-10:] = [90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
R[10:20] = [10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
R[:10:2] = [0, 2, 4, 6, 8]
R[::5] = [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95]

关于yeild的例子

完整的代码

def each_ascii(s):
for ch in s:
yield ord(ch)
return '%s chars' % len(s) def yield_from(s):
r = yield from each_ascii(s)
print(r) def main():
for x in each_ascii('abc'):
print(x) # => 'a', 'b', 'c'
it = each_ascii('xyz')
try:
while True:
print(next(it)) # => 'x', 'y', 'z'
except StopIteration as s:
print(s.value) # => '3 chars' # using yield from in main() will change main() from function to generator:
# r = yield from each_ascii('hello') for ch in yield_from('hello'):
pass main()

代码分析

def each_ascii(s):
for ch in s:
yield ord(ch)
return '%s chars' % len(s)
def yield_from(s):
r = yield from each_ascii(s)
print(r)
for x in each_ascii('abc'):
print(x)
97
98
99
it = each_ascii('xyz')
try:
while True:
print(next(it))
except StopIteration as s:
print(s.value)
120
121
122
3 chars
for ch in yield_from('hello'):
pass
5 chars

总结

有时候,对编程不感冒,但是把一个复杂的知识点多运行几遍,太复杂了,把代码分成小代码运行,最后综合理解,并整理成文。当然,这涉及到调试代码部分,现在我还是个小菜鸟,调试用的不太熟,当然代码量很大的时候可能要用到调试部分。

End



  1. 我总结的一些笔记 ↩︎

Python3基础-高级用法的更多相关文章

  1. django基础之day05,F与Q查询,Q查询的高级用法

    #F与Q查询 #*************************** F 查询 ******************** # F 查询数据库中的其他字段!!! #1.查询库存数大于卖出数的书籍 fr ...

  2. shell中echo基础及高级用法详解-渐入佳境

    --作者:飞翔的小胖猪 --创建时间:2021年2月19日 1.1 基础用法 echo命令用来输出文本,在shell脚本中用来输出提示信息用的比较多. 单引号:原样输出所有的内容,不用转义就能输出特殊 ...

  3. Python3高级用法综合举例

    [本文出自天外归云的博客园] 举例 下面代码围绕一个Student类综合举例说明装饰器.生成器.动态获取/添加类成员.列表推导式.reduce函数.lambda表达式的实际应用: from funct ...

  4. Python函数装饰器高级用法

    在了解了Python函数装饰器基础知识和闭包之后,开始正式学习函数装饰器. 典型的函数装饰器 以下示例定义了一个装饰器,输出函数的运行时间: 函数装饰器和闭包紧密结合,入参func代表被装饰函数,通过 ...

  5. SolrNet高级用法(分页、Facet查询、任意分组)

    前言 如果你在系统中用到了Solr的话,那么肯定会碰到从Solr中反推数据的需求,基于数据库数据生产索引后,那么Solr索引的数据相对准确,在电商需求中经常会碰到菜单.导航分类(比如电脑.PC的话会有 ...

  6. Solr学习总结(六)SolrNet的高级用法(复杂查询,分页,高亮,Facet查询)

    上一篇,讲到了SolrNet的基本用法及CURD,这个算是SolrNet 的入门知识介绍吧,昨天写完之后,有朋友评论说,这些感觉都被写烂了.没错,这些基本的用法,在网上百度,资料肯定一大堆,有一些写的 ...

  7. Git log高级用法

    格式化Log输出 首先,这篇文章会展示几种git log格式化输出的例子.大多数例子只是通过标记向git log请求或多或少的信息. 如果你不喜欢默认的git log格式,你可以用git config ...

  8. python3基础视频教程

    随着目前Python行业的薪资水平越来越高,很多人想加入该行业拿高薪.有没有想通过视频教程入门的同学们?这份Python教程全集等你来学习啦! python3基础视频教程:http://pan.bai ...

  9. Python进阶:切片的误区与高级用法

    2018-12-31 更新声明:切片系列文章本是分三篇写成,现已合并成一篇.合并后,修正了一些严重的错误(如自定义序列切片的部分),还对行文结构与章节衔接做了大量改动.原系列的单篇就不删除了,毕竟也是 ...

随机推荐

  1. zoj3659

    #include<iostream> #include<algorithm> #include<cstring> #define ll long long #inc ...

  2. tomcat启动报错:Annotation-specified bean name 'patrolTrailServiceImpl' for bean class [cn.oppo.inventoryService.patrolTrailServiceImpl] con

    注释-为bean类[目录服务patrolTrailServiceImpl]指定的bean名称“patrolTrailServiceImpl”与同名和[目录服务patrolTrailServiceImp ...

  3. C++设计模式——观察者模式(转)

    前言 之前做了一个性能测试的项目,就是需要对现在的产品进行性能测试,获得测试数据,然后书写测试报告,并提出合理化的改善意见.项目很简单,我们获得了一系列性能测试数据,对于数据,我们需要在Excel中制 ...

  4. 论文阅读笔记三十一:YOLO 9000: Better,Faster,Stronger(CVPR2016)

    论文源址:https://arxiv.org/abs/1612.08242 代码:https://github.com/longcw/yolo2-pytorch 摘要 本文提出YOLO9000可以检测 ...

  5. ubuntu安装界面 会出现不完整情况

    解决方法: alt+鼠标左键或者win+鼠标左键拖动

  6. C. cltt的幸运数LCAtarjan

    /*C: cltt的幸运数 Time Limit: 1 s      Memory Limit: 128 MB Submit Problem Description 一棵树有n个节点,共m次查询,查询 ...

  7. pycaffe简明文档

    pycaffe简明文档 by ChrisZZ, imzhuo@foxmail.com 2018年01月18日19:00:56 说明 caffe的python接口没有官方说明文档,例如查看一个函数的用法 ...

  8. cuda by example【读书笔记2】

    常量内存 用常量内存来替换全局内存可以有效的减少内存带宽 __constant__修饰符标识常量内存,从主机内存复制到GPU上的常量内存时,需要特殊版本的cudaMemcpy(): cudaMemcp ...

  9. MySQL的预处理技术

    所谓的预处理技术,最初也是由MySQL提出的一种减轻服务器压力的一种技术! 传统mysql处理流程 1,  在客户端准备sql语句 2,  发送sql语句到MySQL服务器 3,  在MySQL服务器 ...

  10. bzoj 5099: [POI2018]Pionek

    题解: 还是比较简单的一道题 考虑现在有一个向量,当且仅当下一个向量与它夹角<90度这个向量的模长才会增加 接下来怎么做呢 如果我们去枚举初始向量,向量方向会随着新增向量而变化 随着不断顺时针的 ...