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)
上一篇 2025年8月11日 上午10:43
下一篇 2025年8月11日 上午11:22


相关推荐

  • 爬虫实战–基于requests 和 Beautiful的7160美图网爬取图片

    爬虫实战–基于requests 和 Beautiful的7160美图网爬取图片importreques 初始地址 all url http www 7160 com xiaohua 保存路径 path H school girl 请求头 header User Agent Moz

    2026年3月18日
    2
  • 子网掩码,反掩码与通配符之间的区别

    子网掩码,反掩码与通配符之间的区别1:子网掩码与反掩码的区别:反掩码就是通配符掩码通过标记0和1告诉设备应该匹配到哪位copy。由于跟子网掩码刚好相zd反,所以也叫反掩码例如掩码是255.255.255.0wildcard-mask就是0.0.0.255255.255.255.248反掩就是0.0.0.72:通配符掩码,ospf和Acl这儿用通配符掩码也不是每家的交换机都这么做,像cisco3550就是用的子网…

    2022年7月19日
    39
  • C语言 —— int32_t uint32_t 及size_t

    C语言 —— int32_t uint32_t 及size_t文章目录使用 int64 t 形式代替基本类型使用原因 stdint h 源码 int32 t 和 uint32 t 的区别 size t 在不同机器中定义不同 参考文档使用 int64 t 形式代替基本类型我们都知道 C 语言的基本类型就 char short int 等 但是我们在看其他源码时经常碰到 int32 t int8 t 这种形式的定义 他们是什么呢 其实他们就是基本类型的 typedef 重定义 也就是不同平台下 使用以下名称可以保证固定长度 1 字节 int8 t char2 字节 int1

    2026年3月17日
    2
  • linux访问samba共享_centos7共享文件夹设置

    linux访问samba共享_centos7共享文件夹设置LinuxSamba共享配置教程一、samba介绍linux与windows共享文件一般的方法就是设置共享文件夹和搭建samba服务器。samba服务器作可以windows和linux交互的媒介,可以让windows用户轻松地在电脑上使用图形界面访问linux文件系统,并可以设置写入权限,实用性极佳。二、samba安装首先需要安装samba程序,部分Ubuntu镜像已经自带;执行如下命令即可sudoapt-getinstallsambasudoapt-getins

    2026年3月4日
    3
  • system WinExec ShellExecuteEx

    system WinExec ShellExecuteExwindows编程的时候经常需要调用操作系统提供的命令,比如调用netuser命令可以在系统中新建一个用户等。    1.最简单的调用方法就是使用函数system(),例如    system(“copyd:\\1.rard:\\2.rar”);    属于CRuntimeLibrary,调用该函数会阻塞调用线程。    优点:简单方便,既

    2022年7月11日
    24
  • 腾讯字节双雄齐发力,AI智能体产品抢滩OpenClaw赛道!

    腾讯字节双雄齐发力,AI智能体产品抢滩OpenClaw赛道!

    2026年3月12日
    4

发表回复

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

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