ToB企服应用市场:ToB评测及商务社交产业平台

标题: 【pandas小技巧】--列值的映射 [打印本页]

作者: 耶耶耶耶耶    时间: 2023-8-10 12:46
标题: 【pandas小技巧】--列值的映射
映射列值是指将一个列中的某些特定值映射为另外一些值,常用于数据清洗和转换。
使用映射列值的场景有很多,以下是几种常见的场景:
本篇介绍几个常用的映射小技巧。
1. map 映射

map映射是最简单也是最直接的,比如下面的示例,将性别映射成0和1。
  1. import pandas as pd
  2. df = pd.DataFrame({
  3.     "name": ["Lily", "Harry",
  4.              "Annie", "Joe","Tom"],
  5.     "sex": ["female", "male",
  6.             "female", "male","male"],
  7.     "grade":["A", "E", "B", "F", "A"],
  8. })
  9. df.sex = df.sex.map({
  10.     "female": 0,
  11.     "male": 1,
  12. })
  13. df
复制代码

2. factorize 映射

用map函数映射列的值是最直观的方式,不过如果列的值种类比较多的时候,一个一个映射比较麻烦。
比如下面示例中的 grade 列,不像 sex 列只有两种值。
这时,可以用 factorize 方法来映射。
  1. df = pd.DataFrame({
  2.     "name": ["Lily", "Harry",
  3.              "Annie", "Joe","Tom"],
  4.     "sex": ["female", "male",
  5.             "female", "male","male"],
  6.     "grade":["A", "E", "B", "F", "A"],
  7. })
  8. df.sex = df.sex.factorize()[0]
  9. df.grade = df.grade.factorize()[0]
  10. df
复制代码

factorize函数返回的是一个二元元组,第一个元素是映射之后的数字数组,
第二个元素是索引类型,索引的值就是列中各个不同的值。
  1. df.grade.factorize()
复制代码

所以代码中用的是 factorize()[0]。
这里还有一个小技巧,如果映射后想把得到的值二元化,
比如上面的 grade 列,映射之后有4种不同的值,代表不同的成绩等级。
如果我们只想要不及格(F)和及格(非F)两种情况,那么
  1. df.grade = df.grade.factorize()[0]
  2. df.grade = (df.grade == 3).astype("int")
  3. df
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4