廖雪峰老师的教程上学来的,地址:python高级特性

下面以几个具体示例演示用法:

一、切片

1.1 利用切片实现trim

def trim(s):
while s[:1] == " " or s[-1:] == " ": # 若第1个元素或最后1个元素为空格
if s[:1] == " ":
s = s[1:]
if s[-1:] == " ":
s = s[:-1]
return s

注:字符串可以看做一个list,列表切片的完整写法是 L[start:end],其中end也支持负数,最后一个数用-1表示,第1个数用0表示,如果省略start,表示从0开始,如果省略end,表示到最后1个元素结束。

测试代码:

if trim('hello  ') != 'hello':
print('测试失败1!')
elif trim(' hello') != 'hello':
print('测试失败2!')
elif trim(' hello ') != 'hello':
print('测试失败3!')
elif trim(' hello world ') != 'hello world':
print('测试失败4!')
elif trim('') != '':
print('测试失败5!')
elif trim(' ') != '':
print('测试失败6!')
else:
print('测试成功!')

1.2 切片还有第3个参数,即:L[start:end:skip],比如在1-10之间,把奇数、偶数选出来

list_1 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

odd = list_1[::2]
even = list_1[1::2] print(odd)
print(even)

输出:

[1, 3, 5, 7, 9]
[2, 4, 6, 8, 10]

二、迭代

list_1 = list(range(1, 11))

print("正向迭代:")
for x in list_1:
print(x) print("\n反向迭代:")
for x in reversed(list_1):
print(x) print('\n带索引的迭代:')
for m in enumerate(list_1):
print("list_1[", m[0], "]=", m[1]) dic_1 = {"name": "菩提树下的杨过", "blog": "http://yjmyzz.cnblogs.com/"} # 字典的迭代
print("\ndict字典迭代1:")
for k in dic_1:
print("key:", k, ",value:", dic_1[k]) print("\ndict字典迭代2:")
for v in dic_1.values():
print("value:", v) print('\ndict字典迭代3:')
for k, v in dic_1.items():
print("key:", k, ",value:", v)

输出:

正向迭代:
1
2
3
4
5
6
7
8
9
10 反向迭代:
10
9
8
7
6
5
4
3
2
1 带索引的迭代:
list_1[ 0 ]= 1
list_1[ 1 ]= 2
list_1[ 2 ]= 3
list_1[ 3 ]= 4
list_1[ 4 ]= 5
list_1[ 5 ]= 6
list_1[ 6 ]= 7
list_1[ 7 ]= 8
list_1[ 8 ]= 9
list_1[ 9 ]= 10 dict字典迭代1:
key: name ,value: 菩提树下的杨过
key: blog ,value: http://yjmyzz.cnblogs.com/ dict字典迭代2:
value: 菩提树下的杨过
value: http://yjmyzz.cnblogs.com/ dict字典迭代3:
key: name ,value: 菩提树下的杨过
key: blog ,value: http://yjmyzz.cnblogs.com/

  

三、列表生成器

这个老厉害了!比如:要找出1~100内所有奇数的平方数(即:1,3,5... 这些数的平方数)

a = [x ** 2 for x in range(1, 101) if x % 2 == 1 and x ** 2 <= 100]
print(a)

输出:[1, 9, 25, 49, 81]

再比如,打印出当前目录下的所有文件(不考虑递归子目录) 

import os

print([f for f in os.listdir(".")])

小结:写法就是 [... for ... in .. if ...] ,要生成的list项写在for前面,如果迭代时需要指定条件,写在最后的if中。

四、生成器(generator)

这是python引入的一个新概念,想想刚才学到的列表生成器:

result1 = [x ** 2 for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]]
print(type(result1), result1)

输出:

<class 'list'> [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

不知道大家想过没有:如果for前面的运算比较复杂(比如:求平方根),而for迭代的列表又很大(比如:1千万个),最终列表生成器肯定运行很慢,会严重影响性能。能不能做到『延时』计算?等到真正要用的时候,再按需计算。这就是生成器(generator)要解决的问题,它与[列表生成器]的区别在于,它只保存计算逻辑(即: 保存算法),并不马上计算结果,真正要用的时候,调用next(g)取出下一个计算结果即可,当然,它也支持迭代。

generator1 = (x ** 2 for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
print(type(generator1), generator1) # 取出第1个值
print(next(generator1))
# 取出第2个值
print(next(generator1)) # 打印剩余的值
for x in generator1:
print(x)

输出:

<class 'generator'> <generator object <genexpr> at 0x1087e7f10>
1
4
9
16
25
36
49
64
81
100

从输出类型上看,它的类型是generator,而非list。单纯从语法上看,只要把"列表生成器"的[],换成()即可。

再来一个复杂点的示例,中学我们都学过"杨辉三角",如果用常规思路,打印出杨辉三角,可以参考下面的代码:

import copy

def triangles(limit):
first, second = [1], [1, 1]
print(first)
if limit > 1:
print(second)
if limit == 2:
return
x = copy.copy(second)
while True:
y = copy.copy(first)
[y.append(x[i] + x[i + 1]) for i in range(len(x) - 1)]
y.append(1)
print(y)
x = copy.copy(y)
if len(y) >= limit:
return triangles(10)

输出:

[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
[1, 5, 10, 10, 5, 1]
[1, 6, 15, 20, 15, 6, 1]
[1, 7, 21, 35, 35, 21, 7, 1]
[1, 8, 28, 56, 70, 56, 28, 8, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]

如果,要改写成生成器(generator),该怎么做呢?答案:只要把print(...)的地方,改成yield 即可。

def triangles_generator(limit):
first, second = [1], [1, 1]
yield first
if limit > 1:
yield second
if limit == 2:
return
x = copy.copy(second)
while True:
y = copy.copy(first)
[y.append(x[i] + x[i + 1]) for i in range(len(x) - 1)]
y.append(1)
yield y
x = copy.copy(y)
if len(y) >= limit:
return g = triangles_generator(10)
# 取出前2个
print(next(g))
print(next(g))
# 剩下的用迭代写法输出
for x in g:
print(x)

输出与刚才相同,就不重复贴了。关于这个yield,如果还没理解的,可以对比看下面的示例:

def test1():
return [1, 2, 3] def test2():
print("test2=>1")
yield 1
print("test2=>2")
yield 2
print("test2=>3")
yield 3 print(test1())
g = test2()
print(next(g))
print(next(g))
print(next(g))

输出:

[1, 2, 3]
test2=>1
1
test2=>2
2
test2=>3
3

test2()遇到yield后,会停下来,保存现场,等待下一次调用next()时,才会继续执行。

python高级特性:切片/迭代/列表生成式/生成器的更多相关文章

  1. Python学习 Day 4 函数 切片 迭代 列表生成式 生成器

    定义函数 def my_abs(x):#求绝对值的my_abs函数 if x >= 0: return x else: return –x def nop():#空函数 pass#占位符 参数检 ...

  2. Python 高级特性介绍 - 迭代的99种姿势 与协程

    Python 高级特性介绍 - 迭代的99种姿势 与协程 引言 写这个笔记记录一下一点点收获 测试环境版本: Python 3.7.4 (default, Sep 28 2019, 16:39:19) ...

  3. python协程函数应用 列表生成式 生成器表达式

    协程函数应用 列表生成式 生成器表达式   一.知识点整理: 1.可迭代的:对象下有_iter_方法的都是可迭代的对象 迭代器:对象._iter_()得到的结果就是迭代器 迭代器的特性: 迭代器._n ...

  4. Python高级特性(切片,迭代,列表生成式,生成器,迭代器)

    掌握了Python的数据类型.语句和函数,基本上就可以编写出很多有用的程序了. 比如构造一个1, 3, 5, 7, ..., 99的列表,可以通过循环实现: L = [] n = 1 while n ...

  5. python 基础 切片 迭代 列表生成式

    对list 进行切片 如列表 L = ['Adam', 'Lisa', 'Bart', 'Paul'] L[0:3] ['Adam', 'Lisa', 'Bart'] L[0:3]表示,从索引0开始取 ...

  6. 【转】Python高级特性——切片(Slice)

    摘录廖雪峰网站 定义一个list: 1 L = ['haha','xixi','hehe','heihei','gaga'] 取其前三个元素: >>> L[0],L[1],L[2] ...

  7. Python高级特性——切片(Slice)

    摘录廖雪峰网站 定义一个list: L = ['haha','xixi','hehe','heihei','gaga'] 取其前三个元素: >>> L[0],L[1],L[2] (' ...

  8. Python高级特性:迭代

    迭代的目的是实现遍历出一个可迭代对象的元素,即for循环 基本语法 : for ... in ... 首先只有可迭代对象才可以迭代,判断一个对象是不是可以迭代的方法如下: >>> f ...

  9. Day7 python高级特性-- 切片 Slice

    先举一个例子,取list或tuple中的某几个元素:     1.取 ['a','b','c','d','e','f'] 第1.2.5.6个元素:        >>> a = [' ...

随机推荐

  1. centos6.5生产环境编译安装nginx-1.11.3并增加第三方模块ngx_cache_purge、nginx_upstream_check、ngx_devel_kit、lua-nginx

    1.安装依赖包 yum install -y gcc gcc-c++ pcre-devel openssl-devel geoip-devel 2.下载需要的安装包 LuaJIT-2.0.4.zip ...

  2. centos6中iptables单机网络防火墙的使用

    概述: iptables:基于软件的形式实现的一种防火墙的软件程序 Firewall:工作在主机或网络边缘,对进出的报文按事先定义的规则进行检查,并且由匹配到的规则进行处理的一组硬件或软件,甚至可能是 ...

  3. S5PV210 NAND Flash

    NAND Flash 关于NAND FlashS5PV210的NAND Flash控制器有如下特点:1) 支持512byte,2k,4k,8k的页大小2) 通过各种软件模式来进行NAND Flash的 ...

  4. sklearn聚类模型:基于密度的DBSCAN;基于混合高斯模型的GMM

    1 sklearn聚类方法详解 2 对比不同聚类算法在不同数据集上的表现 3 用scikit-learn学习K-Means聚类 4 用scikit-learn学习DBSCAN聚类 (基于密度的聚类) ...

  5. windows service 的错误 错误 14001:

    1.Windows服务启动时报:“错误 14001:由于应用程序配置不正确,应用程序未能启动.重新安装应用程序可能会纠正这个问题.”的错误. 原因:Windows 服务程序 配置文件中   <a ...

  6. SpringMVC(4.1):Controller接口控制器详解(1)

    原文出处: 张开涛 4.1.Controller简介 Controller控制器,是MVC中的部分C,为什么是部分呢?因为此处的控制器主要负责功能处理部分: 1.收集.验证请求参数并绑定到命令对象: ...

  7. webpack 3之hash、chunkhash和contenthash三者的区别

    在使用webpack 3中,文件名的hash值可以有三种hash生成方式,那具体使用哪一种呢? 1.hash 如果都使用hash的话,所有文件的hash都是一样的,而且每次修改任何一个文件,所有文件名 ...

  8. js十大排序算法详解

    十大经典算法导图  图片名词解释:n: 数据规模k:“桶”的个数In-place: 占用常数内存,不占用额外内存Out-place: 占用额外内存 1.冒泡排序 1.1  原始人冒泡排序 functi ...

  9. [转] 学会fetch的用法

    fetch是web提供的一个可以获取异步资源的api,目前还没有被所有浏览器支持,它提供的api返回的是Promise对象,所以你在了解这个api前首先得了解Promise的用法.参考阮老师的文章 那 ...

  10. Python 可命名元祖

    import collections MytupleClass = collections.namedtuple('MytupleClass',['x','y','z']) obj = Mytuple ...