PYTHON-列表推导式「建议收藏」

PYTHON-列表推导式「建议收藏」1.列表推导式基本格式:[表达式for变量in旧列表]或者[表达式for变量in旧列表if条件]第一个表达式表示最终需要得到的形式#过滤长度小于等于3的人名names=[‘tom’,’lily’,’jack’,’bob’,’haha’]result=[namefornameinnamesiflen(name)>3]print(result)result=[name.capitalize()fo

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

1.列表推导式

基本格式:[表达式 for 变量 in 旧列表] 或者 [表达式 for 变量 in 旧列表 if 条件]
第一个表达式表示最终需要得到的形式

# 过滤长度小于等于3的人名
names = ['tom','lily','jack','bob','haha']

result = [name for name in names if len(name) > 3]
print(result)

result = [name.capitalize() for name in names if len(name) > 3]  #capitalize()所有单词首字母大写
print(result)
----------------------------------------------------
['lily', 'jack', 'haha']
['Lily', 'Jack', 'Haha']

Jetbrains全家桶1年46,售后保障稳定

携带if条件

#0~5 偶数 0~9 奇数 构成列表
result = [(x,y) for x in range(5) if x%2 == 0 for y in range(10) if y%2 != 0]  #可以嵌套for循环
print(result)
-------------------------------------------------
[(0, 1), (0, 3), (0, 5), (0, 7), (0, 9), (2, 1), (2, 3), (2, 5), (2, 7), (2, 9), (4, 1), (4, 3), (4, 5), (4, 7), (4, 9)]

没有if 条件,注意 i 代表列表

list1 = [[2,5,3],[2,5,6],[3,8,9],[7,8,5]]
list2 = [i[-1] for i in list1]
print(list2)
-----------------------------------------------------
[3, 6, 9, 5]

if…else

dict1 = { 
   'name':'lili','salary':5000}
dict2 = { 
   'name':'lyly','salary':4000}
dict3 = { 
   'name':'tom','salary':3500}
dict4 = { 
   'name':'jack','salary':8000}
list1 = [dict1,dict2,dict3,dict4]
newlist = [{ 
   'name':dict['name'],'salary':dict['salary']+300} if dict['salary']>5000 else { 
   'name':dict['name'],'salary':dict['salary']+800} for dict in list1]
print(newlist)  #dict 表示取出对应键的值,运用dict把更改后的salary在原字典中进行更新
----------------------------------------------------
[{ 
   'name': 'lili', 'salary': 5800}, { 
   'name': 'lyly', 'salary': 4800}, { 
   'name': 'tom', 'salary': 4300}, { 
   'name': 'jack', 'salary': 8300}]

2.集合推导式

{}类似于列表推导式,在列表推导式的基础上添加一个去除重复项

list1 = [1,2,1,2,5,6,8,9,8,7,9]
set1 = { 
   x for x in list1 if x>5}
print(set1)
----------------------------------------------------
{ 
   8, 9, 6, 7}

3.字典推导式

dict1 = { 
   'a':'A','b':'B','c':'C','d':'C'}
newdict = { 
   value:key for key,value in dict1.items()}
print(newdict)
-----------------------------------------------------
{ 
   'A': 'a', 'B': 'b', 'C': 'd'}

4.生成器

通过列表生成式(列表推导式),我们可以直接创建一个列表,但是,受到内存限制,列表容量肯定是有限的。而且,我们创建一个包含100万个元素的列表,那后面绝大多数元素占用的空间都白白浪费了。所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间,在python中,这种一边循环一边计算的机制,成为生成器:generator。
得到生成器的方式:
1.通过列表推导式得到生成器
[] 是列表推导式,()是生成器

g = (x*3 for x in range(20))
print(type(g))
------------------------------------------------
<class 'generator'>

通过使用g.next()方式得到元素,或者使用next(g)得到元素,每调用一次则会产生一个元素。
若生成器产生的元素用完,继续调用则会抛出异常StopIteration
利用try…except的方式解决异常

g = (x*3 for x in range(10))
while True:
    try:
        e = next(g)
        print(e)
    except:
        print('没有更过元素了')
        break

2.借助函数完成
只要函数中出现了yield关键字,说明函数就不是函数了,是一个生成器,借助于next(),next()得到元素

def func():
    n = 0
    while True:
        n += 1
        yield n

g = func()
print(g)  # generator
print(next(g))

斐波那契数列

def fib(length):
    n=0
    a,b=0,1
    while n < length:
        yield b    #return b 并且暂停
        a,b = b,a+b
        n+=1
    return '没有更多元素'   #当while循环执行完之后,返回return的值
g = fib(8)
print(next(g))

send 方法 和__next__()一样 都可以让生成器执行到下一个yield,send可以向yield的位置传递参数,向每次生成器调用中传值,不能给最后一个yield发送值 会报错,第一次执行函数是不能用send,第一次调用sned(None)

5.生成器的应用

进程 > 线程 > 协程
概念:比如迅雷下载1.0G的电影,叫做进程,然后迅雷将1.0G的电影按顺序分为10份,这10份叫做线程,然后其中的一份再分为5份,每一份就叫做协程。

def task1(n):
    for i in range(n):
        print("正在搬第{}块砖!".format(i))
        yield None
def task2(n):
    for i in range(n):
        print("正在听第{}首歌!".format(i))
        yield None
g1 = task1(6)
g2 = task2(6)
while True:
    try:
        g1.__next__()
        g2.__next__()
    except:
        break
# 交替输出

6.迭代器

可迭代的对象:生成器、元组、列表、集合、字典、字符串
如何判断一个对象是否可迭代?

from collections import Iterable
list1 = [1,4,5,6,8]
f = isinstance(list1,Iterable)
print(f)  #True

生成器是可迭代的,并且是迭代器;列表是可迭代的,但不是迭代器。
迭代器只能往前不能往后
可以被next()函数调用,不断返回下一个值得对象称为迭代器:Iterator。

list1 = [1,4,5,6,8]
list1 = iter(list1)
print(next(list1))

通过iter()函数将可迭代的变成一个迭代器

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/203666.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 大数据面试题(六)—-HBASE 面试题

    大数据面试题(六)—-HBASE 面试题版权声明:本文为CSDN博主「北京小辉」的原创文章,遵循CC4.0BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/silentwolfyh/article/details/103864901———————————————————————————————————“无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家。教程不仅…

    2022年5月30日
    31
  • 使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」

    使用ParameterizedThreadStart委托向线程函数传送参数「建议收藏」在不传递参数情况下,一般大家都使用ThreadStart代理来连接执行函数,ThreadStart委托接收的函数不能有参数,也不能有返回值。如果希望传递参数给执行函数,则可以使用带参数的ParameterizedThreadStart委托,     publicdelegatevoidParameterizedThreadStart(Objectobj)可以将要传送给

    2022年7月15日
    20
  • Oracle 判断 并 手动收集 统计信息 脚本

    Oracle 判断 并 手动收集 统计信息 脚本

    2021年9月17日
    47
  • xiao776php,《xiao 776》_xiao 776_NEWS下载网「建议收藏」

    xiao776php,《xiao 776》_xiao 776_NEWS下载网「建议收藏」康平候爷一五一十述说了一遍,因是夏钰之伤在腿上,这段时日无法下榻,他自己已然焦躁得不行。xiao776因此,趋向正常性(normality)的倾向是一种格局的倾向,而格局里面的自我和物体则受制于格局以及格局与其内容的不变联结,这里的内容意指物体和自我。面对阻在他身前的最后一队死士,他疯了一般,浑身爆发出森然的杀意,弯刀过处全是一片飞扬的血肉,守卫渐渐抵挡不住,废宫越来越在眼前。提示:xiao7…

    2022年10月7日
    4
  • pytest运行_pytest执行多个py文件

    pytest运行_pytest执行多个py文件前言pytest运行完用例之后会生成一个.pytest_cache的缓存文件夹,用于记录用例的ids和上一次失败的用例。方便我们在运行用例的时候加上–lf和–ff参数,快速运行上一

    2022年7月31日
    10
  • 测试开发工程师常见面试题[通俗易懂]

    测试开发工程师常见面试题[通俗易懂]1.CPU和GPU的区别CPU力气大啥P事都能干,还要协调。GPU上面那家伙的小弟,老大让他处理图形,这方面处理简单,但是量大,老大虽然能处理,可是老大只有那么几个兄弟,所以不如交给小弟处理了,小弟兄弟多,有数百至数千个,而且是专门只干这行和只能干这行。详细解释2.推荐的算法有哪些?1基于人口统计学的推荐2基于内容的推荐3协同过滤4混合推荐算法3….

    2022年5月16日
    70

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号