sal.get('name').capitalize() 首字母大写
###注意startswith('函数的试用是判断字符串的')
if list==type(i): #判断type(i) 是否是同一个 类型
#如果吧集合放在这每次for循环前面的都会被覆盖 所以放for里面
for a in f:
dic = {} 每次for循环后最后一个值都会把上一个值覆盖(列题在下方)
# 1、文件内容如下,标题为:姓名,性别,年纪,薪资
# egon male 18 3000
# alex male 38 30000
# wupeiqi female 28 20000
# yuanhao female 28 10000
# 要求:
# 从文件中取出每一条记录放入列表中,
# 列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式
# #
list1=[] with open("a.txt",mode="rt",encoding="utf8")as f:
#如果吧集合放在这每次for循环前面的都会被覆盖 所以放for里面
for a in f:
dic = {}
name,sex,age,salary=a.replace('\n','').split(' ') #解压赋值
dic['name']=name
dic['sex']=sex
dic['age']=age
dic['salary']=salary
list1.append(dic)
print(list1)
# 2 根据1得到的列表,取出所有人的薪资之和
salarys=(eval(sal.get('salary')) for sal in list1)
salarysum=sum(salarys) print(salarysum)
#
# # 3 根据1得到的列表,取出所有的男人的名字
out_1=(sal.get('sex') for sal in list1 if sal.get('sex') !='female')
print(list(out_1))
# 4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
out_2=(sal.get('name').capitalize() for sal in list1 )
print(list(out_2))
5 根据1得到的列表,过滤掉名字以a开头的人的信息
name_1=(i for i in list1 if not i.get("name").startswith("a") )###注意startswith('函数的试用是判断字符串的')
print(list(name_1))
# 6 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
def func(x,n=0,a=1): 明确一个要有结束值
if x==0:
return
print(n)
n,a=n+a,n
记得赋值在函数内才可以有变化 不然下次循环的话就归零
x-=1
func(x,n,a)
func(10)
# 7 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值
l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]]
def func(list1):
for i in list1:
if list==type(i): #判断type(i) 是否是同一个 类型
func(i)
else:
print(i)
func(l)