一、列表生成式
使用列表生成式找出1~num之间的所有质数
def isPrime(num):
for i in range(2,num):
if num % i == 0:
return False
else:
return True
print([i for i in range(2,101) if isPrime(i)])
使用列表生成式找出目录/var/log下以.log结尾的文件
import os
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
练习:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整
数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别
为(5,5),(3,7))
[2,3,5,7]
- 输入描述:
输入包括一个整数n,(3 ≤ n < 1000) - 输出描述:
输出对数 - 示例1 :
输入:
10
输出:
2
num = int(input())
#1.先判断2~num之间有多少质数
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,num) if isPrime(i)]
print(primeli)
1.先从列表里拿出两个数
2.判断两个数之和是否等于num
primecount = 0
for item in primeli:
if (num - item) in primeli and item <= num - item:
primecount += 1
print(primecount)
二、字典生成式
需求1:假设有20个学生,学生名为westosX,学生成绩在60~100之间,
筛选出成绩在90分以上的学生
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})
需求2:将所有key值变为大写
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:大小写、value值和并,统一以小写输出
d = dict(a=2,b=1,c=2,B=9,A=10)
new_d = {'a':12,'b':10,'c':2}
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.lower(),0) + d.get(k.upper(),0) for k in d})