博主信息
博文 2
粉丝 0
评论 1
访问量 3968
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
python学习002-pandas VS excel给成绩赋值等级
哆哆-程序学习笔记
原创
2102人浏览过

【问题】有一张成绩表如下,在总分后面添加一列,按如下要求输入等级

0.png等级如下:

 成绩
等级
90以上A
80-90B
60-79C
0-59D

【知识点】

apply函数

apply函数是`pandas`里面所有函数中自由度最高的函数。该函数如下:

DataFrame.apply(func, axis=0, broadcast=False, raw=False, reduce=None, args=(), **kwds)

该函数最有用的是第一个参数,这个参数是函数,相当于C/C++的函数指针。

这个函数需要自己实现,函数的传入参数根据axis来定,比如axis = 1,就会把一行数据作为Series的数据

结构传入给自己实现的函数中,我们在函数中实现对Series不同属性之间的计算,返回一个结果,则apply函数

会自动遍历每一行DataFrame的数据,最后将所有结果组合成一个Series数据结构并返回。

【代码】

```python

# -*- coding: UTF-8 -*-

import pandas as pd

def get_letter_grade(score):

    if score>=90:

        return "A"

    elif score>=80:

        return "B"

    elif score>=60:

        return "C"

    else:

        return "D"

d=pd.read_excel('pandas VS excel给成绩赋值等级.xlsx')

print(d)

d['等级']=d['总分'].apply(lambda x: get_letter_grade(x))

print(d)

d.to_excel('pandas VS excel给成绩赋值等级_out.xlsx',index=False)

print("done")

```

过程解析:

1.把Excel成绩读入打印出来为

1.png

2.d['等级']=d['总分'].apply(lambda x: get_letter_grade(x))

新建一个“等级“的列,并赋值等级如下

2.png

3.

d.to_excel('pandas VS excel给成绩赋值等级_out.xlsx',index=False)

输出为excel文件内容如下

3.png

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学