darknight006 发表于 2022-11-19 07:54:01

遇到了'NoneType' object has no attribute 'replace'的问题

def insert_conditions(df, s_conditions, reference_column, new_column_name, position):
    data = df.insert(column = new_column_name,loc = position, value = df['Reason for absence']).replace({'Reason':s_conditions})
df = load_data()
s_conditions = load_conditions()
insert_conditions(df, s_conditions, reference_column='Reason for absence', new_column_name='Reason', position=0)
print(df.iloc[:5][['Reason','ID', 'Reason for absence', 'Month of absence']].to_string())

想要javascript:;这种效果 但是报错了。。

zhangjinxuan 发表于 2022-11-19 08:41:37

这说明了有一个变量返回了 None,而导致的错误,报错大意就是 “None"类型没有属性‘replace',检查检查,调试调试

报错的是第几行?

suchocolate 发表于 2022-11-19 09:39:33

本帖最后由 suchocolate 于 2022-11-19 10:21 编辑

df.insert()不返回数据,默认返回None,数据直接插入到df里。

tommyyu 发表于 2022-11-19 09:44:34

df 的 insert 方法的返回值是 None ,导致在执行 insert_conditions 函数时, python 就会执行
data = df.insert(column = new_column_name,loc = position, value = df['Reason for absence']).replace({'Reason':s_conditions})然后变成data = None.replace({'Reason':s_conditions})然后就会报错

darknight006 发表于 2022-11-19 21:06:13

zhangjinxuan 发表于 2022-11-19 08:41
这说明了有一个变量返回了 None,而导致的错误,报错大意就是 “None"类型没有属性‘replace',检查检查, ...

第二第五行都报错了

darknight006 发表于 2022-11-19 21:07:17

tommyyu 发表于 2022-11-19 09:44
df 的 insert 方法的返回值是 None ,导致在执行 insert_conditions 函数时, python 就会执行
然后变成然 ...

哦哦哦 明白你意思了,那这种我要解决这个问题该咋写嘞

darknight006 发表于 2022-11-19 21:08:43

suchocolate 发表于 2022-11-19 09:39
df.insert()不返回数据,默认返回None,数据直接插入到df里。

这个我在也查到了大佬 但是怎么解决啊

tommyyu 发表于 2022-11-19 21:09:37

darknight006 发表于 2022-11-19 21:08
这个我在也查到了大佬 但是怎么解决啊

这个代码只有一个片段,也看不出来怎么改,能把完整代码发一下么

darknight006 发表于 2022-11-19 21:29:59

tommyyu 发表于 2022-11-19 21:09
这个代码只有一个片段,也看不出来怎么改,能把完整代码发一下么

%matplotlib inline
import matplotlib.pyplot as plt
import numpy as np
import scipy as sp
import pandas as pd

def load_data():
    return pd.read_csv('Absenteeism_at_work.csv',sep = ';')
def load_conditions():
    return pd.read_table('conditions.txt', names=['Reason for absence'])
def insert_conditions(df, s_conditions, reference_column, new_column_name, position):
    data = df.insert(column = new_column_name,loc = position, value = df['Reason for absence']).replace({'Reason':s_conditions})


df = load_data()
print(df.info())
df = load_data()
s_conditions = load_conditions()
insert_conditions(df, s_conditions, reference_column='Reason for absence', new_column_name='Reason', position=0)
print(df.iloc[:5][['Reason','ID', 'Reason for absence', 'Month of absence']].to_string())

这是目前写到的部分,之前的函数都测试过没啥问题

阿奇_o 发表于 2022-11-19 23:29:59

本帖最后由 阿奇_o 于 2022-11-19 23:35 编辑

darknight006 发表于 2022-11-19 21:29
这是目前写到的部分,之前的函数都测试过没啥问题

df.insert 函数没返回(即返回None, None属于NoneType理解?)
df.insert()后,没有返回,但 df 被“就地改变” ,所以要对修改后的df 用 replace() ,

那就另起一行 df.replace(...)

另外想说,你的几个函数定义得是不是有点多余,有点脱了裤子放屁的感觉。。{:10_277:}

ps: 数据分析或数据处理,尽量用 Jupyter Notebook或IPython等类似交互式界面(省去你一堆print,)。。
很方便,可以一步一步先确定拿到自己需要的数据或效果, 最后有必要的话,再梳理和整合到一起。

darknight006 发表于 2022-11-20 16:58:46

阿奇_o 发表于 2022-11-19 23:29
df.insert 函数没返回(即返回None, None属于NoneType理解?)
df.insert()后,没有返回,但 df 被 ...

这是我作业。。。一个函数代表一个题目。。然后后面还得调用啥的就。。{:10_245:}
我用的就是jupyter {:10_245:}
还有就是大佬我分开写只执行了df.insert()啊{:10_245:}
页: [1]
查看完整版本: 遇到了'NoneType' object has no attribute 'replace'的问题