我试图写一个列表理解,如果这个值是一个整数,它将乘以1,000,000,但如果它不是一个整数,那么它的值将是'np.NaN‘。
这是我的密码:
energy['Energy Supply'] = [n*1000000 if isinstance(n,int) == True else n == 'np.Nan' for n in energy['Energy Supply']]
返回的数据帧显示“能源供应”列中没有整数的情况下为False。
然后我试着写另一个理解列表来解决这个问题:
energy['Energy Supply'] = [n.replace(to_replace='False',value='np.Nan') for n in energy['Energy Supply']]
我发现了一个错误:
AttributeError跟踪(最近一次调用) in () 5能源“能源供应”=[n.replace(to替换=‘False’),能源“能源供应”中n的值=‘np.nan’6返回能量-7 answer_one()
在answer_one() 3 energy.columns =‘energy.columns’,‘能源供应’,'%可再生‘4能源’能源供应‘= [n*1000000如果是(n,int) == True else n == str('np.nan')为n中的能源“能源供应”能源“能源供应”[6]中n的值=‘np.nan’=‘np.nan’6返回能量7 answer_one()
在(.0) 3 energy.columns =‘energy.columns’,‘能源供应’,'%可再生‘4能源’能源供应‘= [n*1000000 ]中,如果(n,int) == True == str('np.nan')为n在能源“能源供应”能源“能源供应”[6]中n的值=‘np.nan’=‘np.nan’6返回能量7 answer_one()
AttributeError:“bool”对象没有属性“替换”
预先感谢堆栈溢出社区。
发布于 2020-01-28 06:01:53
您的第一段代码不能正常工作-- b/c之后使用的是==
energy['Energy Supply'] = [n*1000000 if isinstance(n,int) == True else 'np.Nan' for n in energy['Energy Supply']]
要摆脱False
,可以使用映射
d={False:np.nan}
energy['Energy Supply']=energy['Energy Supply'].map(d)
发布于 2020-01-28 06:10:37
我不确定我是否正确地理解了你,但如果是的话-这有用吗?
energy['Energy Supply'] = [n*1000000 if isinstance(n,int) == True else 'np.Nan' for n in energy['Energy Supply']]
https://stackoverflow.com/questions/59942563
复制相似问题