列表生成式,字典生成式

列表生成式,字典生成式

列表生成式

相较于之前使用for循环生成列表的方式,这种写法更专业
可能是因为这更加地符合python编程规范与思维
而之前的使用for循环生成的方式则更类似于以前的c语言编程写法

# 生成一个列表,列表元素分别为[1**1 2**2 3**3...9**9]
import math

li = []
for i in range(1, 10):
    li.append(i ** i)
print(li)

print([i ** i for i in range(1, 10)])

# 在上面的基础上,筛选出偶数项
print([i ** i for i in range(1, 10) if i % 2 == 0])

# S1='ABC' S2='123' A1 A2 A3..    输出两字符串元素之间的所有组合
print([i + j for i in 'ABC' for j in '123'])

# 找出1~10之间的所有偶数.并且返回一个列表(包含以这个偶数为半径的园的面积)
# print(math.pi)
# for r in range(2, 11, 2):
#     square = math.pi * r * r
#     li.append(square)
# print(li)

print([math.pi * r * r for r in range(2, 11, 2)])

# 结合函数,使用列表生成式
def square(r):
    res = math.pi * r * r
    return res
print([square(i) for i in range(2,11,2)])

对于列表生成式的执行,我的理解是:
print([i+j for i in "ABC" for j in "123" ])
	生成式中的追加元素为i+j,i和j是通过两个循环语句生成的,两个循环语句的相对位置,决定了i,j生成的先后顺序

for i in "ABC":        #这个语句即上面列表生成式最左侧的列表追加元素的外部循环条件
    for j in "123":     #这个语句即上一循环语句内部的循环条件
        listname.append(i+j)  #这里的i+j即上面列表生成式最左侧的参数
print(listname)

在这里插入图片描述
简单应用示例:

生成一个列表,存储指定范围内的素数

def isprime(num):
    for i in range(2,num):
        if num % i == 0:
            return False
    else:
            return True
primeli = [i for i in range(2,100) if isprime(i)]   # 使用函数和列表生成式生成指定列表

在这里插入图片描述

字典生成式

利用上面的列表生成式,我们可以快速地生成指定元素组成的列表
而同样地,使用列表生成式,我们也可以将其转换为元组,集合,从而达到快速生成
但是这却无法生成字典类型,因此还有字典生成式

list = {num:score for score in range(100) if score <50 for num in (1,2,43,45,5)}
这个语句生成的字典{1: 49, 2: 49, 43: 49, 45: 49, 5: 49}。并不是两层循环嵌套失败了,而是相同的key值的元素,更新了原来的值
可见这种循环方式并不适合用于字典生成键

(1)
import random

stuInfo = {}
# 生成一个随机值的字典,在该字典的数据的基础上,使用字典生成式生成字典
for i in range(20):
    name = 'westos' + str(i)
    score = random.randint(60, 100)
    stuInfo[name] = score
print(stuInfo)

# highscore ={}
# for name,score in stuInfo.items():
#     if score > 90:
#         highscore[name] = score
# print(highscore)
print({name: score for name, score in stuInfo.items() if score > 90})
# 筛选出成绩90以上的数据对

(2)
d = dict(a=1,b=2)
print(d)
new_d = {}
for i in d:
    new_d[i.upper()] = d[i]
print(new_d)

print({k.upper():v for k,v in d.items()})
# 将字典的索引都变为大写,输出字典

(3)
d = dict(a=1,b=2,c=3,B=8,A=10)
# new_d = {}
# for k,v in d.items():
#     low_k = k.lower()
#     if low_k not in new_d:
#         new_d[low_k] = v
#     else:
#         new_d[low_k] += v
#
# print(new_d)
print({k.lower():d.get(k.upper(),0)+d.get(k.lower(),0)for k in d})
# 将同一字母的大小写的值合并为一对键值对

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值