列表生成式
- Python内置的一种极其强大的生成列表 list 的表达式。返回结果必须是列表。
- 格式:[ 变量表达式 for 变量 in 表达式 if 变量的判断条件(结果为True 或者False)]
需求1:接收变量 k a b
使用循环列表生成列表
将字符串 ‘51 5000 10000’ 转化成三个整形数字并且有三个变量接收
s = '51 5000 10000'
a = s.split()
li = []
for i in s.split():
li.append(int(i))
k,a,b=li
print(li)
使用列表生成式生成列表
s = '51 5000 10000'
li = [int(i) for i in s.split()]
print(li) 这里的生成方式会生成了一个列表
k,a,b=li
print(k,a,b) 而这里生成的是整数,将字符串转换为整数
[51, 5000, 10000]
51 5000 10000
需求2:生成一个列表,列表的元素分别为[11 22 9**9 ]
使用for循环生成列表
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]) 这个是1-10内偶数的幂次方算法
列表生成式变形之for循环
使用for循环生成列表
dict_d = [
[1,2,3],
[4,5,6],
[7,8,9]
]
list_li=[]
for i in dict_d:
for i2 in i : 在for循环里面嵌套for循环来进行操作
list_li.append(i2)
print(list_li)
使用列表生成式生成列表
dict_d = [
[1,2,3],
[4,5,6],
[7,8,9]
]
list_li=[]
print([item2 for item1 in dict_d for item2 in item1])
内置函数chain,其参数为任意个序列 返回值为所有序列中的所有元素
dict_d = [
[1,2,3],
[4,5,6],
[7,8,9]
]
list_li=[]
prin
from itertools import chain
print(list(chain(*dict_d)))
1.找出1~10之间的所有偶数,并且返回一个列表(包含以这个偶数为半径的园的面积)
方法一:使用for循环返回列表并且计算
import math
li = []
for r in range(2, 11, 2):
sqa= math.pi * r * r
li.append(sqa)
print(li)
方法二:列表生成式返回列表计算
import math
li = []
print([ math.pi * r * r for r in range(2,11,2) ])
方法三:受用函数返回列表
import math
def sqa (r):
rs = math.pi *r *r
return rs
print([sqa(i) for i in range(2,11,2)])
找出1~100之间的所有素数 (列表生成式 + 函数
def deck(num):
for i in range(2,num):
if num %2 ==0:
return False
else:
return True
print([i for i in range(2,101) if deck(i)])
找出/var/log目录中,所有以.log结尾的文件名或者目录名
import os
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
列表的字符串的大写改成小写,不是字符串的去掉
isinstance(变量,数据类型) #判断变量是不是该数据类型,是的话返回Ture,不是返回False
li = ['hello','World',16,67,12.3,False,'Apple']
print([s.lower() for s in li if isinstance(s,str)])
练习
题目需求:
对于一个十进制的正整数, 定义f(n)为其各位数字的平方和,如:
f(13) = 12 + 32 = 10
f(207) = 22 + 02 + 72 = 53
下面给出三个正整数k,a, b,你需要计算有多少个正整数n满足a<=n<=b,
且k*f(n)=n
输入:
第一行包含3个正整数k,a, b, k>=1, a,b<=1018, a<=b;
输出:
输出对应的答案;
范例:
输入: 51 5000 10000
输出: 3
定义函数 计算每一位数字的平方和
def f(n):
sum = 0
while n >0 :
y = n%10
n = n//10
sum += y ** 2
return sum
#列表生成式,将输入的字符串转化成元素为整形数字的列表
in_put = [ int(i) for i in input(':').split() ]
#列表生成式,将满足条件的数字放到一个新的列表中
out_put = [ i for i in range(in_put[1],in_put[2]) if in_put[0] * f(i)== i]
#输出存放满足条件数组的列表长度即可得到满足的个数
print(len(out_put))
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
[2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000) - 输出描述:
输出对数 - 示例1 :
输入:
10
输出:
2
def su_all(n):
for i in range(2,n):
if n%i ==0:
return False
else:
return True
def add(n):
sum = 0
for i in range(2,int(n/2)+1):
if su_all(i) and su_all(n -i ):
sum+=1
return sum
num= int(input('请输入一个小于1000的正整数:'))
print(add(num))
请输入一个小于1000的正整数:10
2