关于字典和for循环的问题
下面这个代码,我想请教的问题在#后面def func(string):
s = string.lower()
dic = {}
for ch in s:
if ch.isalpha():
if ch not in dic.keys():
dic = 1
else:
dic += 1
print(dic.keys())
result = sorted(dic.items(), key = lambda x:x, reverse = True) #这句话我实在是没有理解到意思,想请教一下各位
for k, v in result #这句话为啥for后面跟了两个参数呢,不太理解这两个参数怎么运行的
print(k, v)
print(result)
func("Apple app!")
本帖最后由 suchocolate 于 2021-10-12 23:22 编辑
问题一:对键和值元祖排序,lambda x:x,就是以值进行排序,reverse=True就是大到小,sorted基本使用:https://www.runoob.com/python/python-func-sorted.html
问题二:就是自动解包,直接看案例:>>> ls1 = [(1, 'a'), (2, 'b'), (3, 'c')]
# 普通for
>>>for i in ls1:
print(i)
(1, 'a')
(2, 'b')
(3, 'c')
# 手工解包
>>> for i in ls1:
print(*i)
1 a
2 b
3 c
# 让for自动解
>>> for k, v in ls1:
print(k, v)
1 a
2 b
3 c
另外result后面落下了冒号。 1、dic.items() 列表返回可遍历的(键, 值) 元组数组,sorted()里key指定一个参数的函数,用于从每个列表元素中提取比较键,这里是取元组里第二个元素进行比较然后排序
2、因为result是一个元素是二元组的列表,所以用两个参数解包元组
说的可能不太正确,大佬请指正 suchocolate 发表于 2021-10-12 22:59
问题一:对键和值元祖排序,lambda x:x,就是以值进行排序,reverse=True就是大到小,sorted基本使用:h ...
第一个问题里的网站我看了,还有几点想问一下
>>> L=[('b',2),('a',1),('c',3),('d',4)]
>>> sorted(L, cmp=lambda x,y:cmp(x,y)) # 利用cmp函数
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
这个cmp我还是没有看懂
>>> sorted(L, key=lambda x:x) # 利用key
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
这个key我求证一下,看我理解正确与否:x的意思是根据第几个元素进行排序的意思吗
第二个自动解包的问题
能否理解成直接把元组给拆分了显示出来 Jerry~Mouse 发表于 2021-10-13 16:14
第一个问题里的网站我看了,还有几点想问一下
>>> L=[('b',2),('a',1),('c',3),('d',4)]
1)sorry,连接给错了,现在python3的sorted看这个:https://www.runoob.com/python3/python3-func-sorted.html
2)x是lambda函数的参数,表示带入到lambda函数的实参,如上面的第一个参数x('b',2),然后lambda取x,也就是第一个组的key就是2,然后再依次带入参数,都是取x,让有以这个排序。
3)不太理解,你是想这样:
ls1 = [('a', 1), ('b', 2), ('c', 3), ('d', 4)]
然后直接显示:a 1 b 2 c 3 d 4
页:
[1]