鱼C论坛

 找回密码
 立即注册
查看: 1297|回复: 3

[已解决]python中dataframe替换空值失败

[复制链接]
发表于 2021-9-12 15:27:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. import pandas as pd
  2. df1=pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1
复制代码

  1. df1[0] = df1[0].fillna('123')
  2. df1
复制代码


请教各位大佬为什么空值没有被替换掉,是哪边有问题吗?
最佳答案
2021-9-12 16:23:23
本帖最后由 傻眼貓咪 于 2021-9-12 16:26 编辑

換成 0:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = 0
  4. print(df1)
复制代码
  1.    0  1  2
  2. 0  0  2  3
  3. 1  3  2  2
  4. 2  4  5  6
  5. 3  8  8  5
复制代码
換成 123:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = 123
  4. print(df1)
复制代码
  1.      0  1  2
  2. 0  123  2  3
  3. 1    3  2  2
  4. 2    4  5  6
  5. 3    8  8  5
复制代码
換成空值:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = None
  4. print(df1)
复制代码
  1.       0  1  2
  2. 0  None  2  3
  3. 1     3  2  2
  4. 2     4  5  6
  5. 3     8  8  5
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-9-12 15:37:14 | 显示全部楼层
本帖最后由 傻眼貓咪 于 2021-9-12 15:41 编辑
  1. import pandas as pd
  2. import numpy as np
  3. df1 = pd.DataFrame([[np.nan,2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  4. print(df1)

  5. df1[0] = df1[0].fillna('123')
  6. print(df1)
复制代码
  1.      0  1  2
  2. 0  NaN  2  3
  3. 1  3.0  2  2
  4. 2  4.0  5  6
  5. 3  8.0  8  5
  6.      0  1  2
  7. 0  123  2  3
  8. 1  3.0  2  2
  9. 2  4.0  5  6
  10. 3  8.0  8  5
复制代码
""不是空值
不要用numpy也行,直接放 None:
  1. import pandas as pd
  2. # import numpy as np
  3. df1 = pd.DataFrame([[None,2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  4. print(df1)

  5. df1[0] = df1[0].fillna('123')
  6. print(df1)
复制代码
  1.      0  1  2
  2. 0  NaN  2  3
  3. 1  3.0  2  2
  4. 2  4.0  5  6
  5. 3  8.0  8  5
  6.      0  1  2
  7. 0  123  2  3
  8. 1  3.0  2  2
  9. 2  4.0  5  6
  10. 3  8.0  8  5
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-12 15:56:51 | 显示全部楼层
傻眼貓咪 发表于 2021-9-12 15:37
""不是空值
不要用numpy也行,直接放 None:

不是空值的话,对于“”应该怎么处理呢。
我用python爬取的数据,是“”。
我爬取之后存放入mysql,再读取到jupyter,dataframe里显示是空白。
我想要把这个空白值(即“”)换成0,应该怎么处理呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-12 16:23:23 | 显示全部楼层    本楼为最佳答案   
本帖最后由 傻眼貓咪 于 2021-9-12 16:26 编辑

換成 0:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = 0
  4. print(df1)
复制代码
  1.    0  1  2
  2. 0  0  2  3
  3. 1  3  2  2
  4. 2  4  5  6
  5. 3  8  8  5
复制代码
換成 123:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = 123
  4. print(df1)
复制代码
  1.      0  1  2
  2. 0  123  2  3
  3. 1    3  2  2
  4. 2    4  5  6
  5. 3    8  8  5
复制代码
換成空值:
  1. import pandas as pd
  2. df1 = pd.DataFrame([['',2,3],[ 3, 2,2],[4,5,6],[8,8,5]])
  3. df1.loc[0,0] = None
  4. print(df1)
复制代码
  1.       0  1  2
  2. 0  None  2  3
  3. 1     3  2  2
  4. 2     4  5  6
  5. 3     8  8  5
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-18 16:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表