十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
方法用错了, 首先不能是DataFrame的applymap方法 这个方法是对每一个元素进行处理的
创新互联,专注为中小企业提供官网建设、营销型网站制作、自适应网站建设、展示型成都做网站、成都网站设计、成都外贸网站建设等服务,帮助中小企业通过网站体现价值、有效益。帮助企业快速建站、解决网站建设与网站营销推广问题。
其次, 处理函数(你的func_wd)是接受一个值, 返回一个值, 不是接受一堆值然后循环
def func_wd(x) 这个x就是wd那一列中的某一个值, 里面直接分支返回就行了:
在map这个方法的时候, 用Series的apply:
data['wd'] = data['wd'].apply(fuc_wd)
这样就行了
students = [('john', 'A', 15), ('jane', 'B', 12), ('dave','B', 10)]
print(sorted(students,key=lambda s: s[0]))
key指定一个接收一个参数的函数,这个函数用于从每个元素中提取一个用于比较的关键字。默认值为None
例子
为啥会这样呢?默认不是应该按升序排列。
仔细看 我们lambda返回的是一个元祖,(布尔,布尔,绝对值)
由于key函数主要作用是根据我们自己的要求,取出指定的元素来进行排序,不过我们现在返回的是一个元祖,所以我们首先按布尔进行排序,当有相同的我们在往后面一个元素找,然后进行排序,所以就变成这样了。
可以使用ascii码表来判断,小写字母的ascii码是97-122,大写字母的ascii码是65-90.
代码
运行结果:
运行结果
附ascii码表:
ascii码表
i = input('Input number: ')
if int(i) % 2 == 1:
print('奇数')
else:
print('偶数')