解决unsupported operand type(s) for /: ‘str‘ and ‘int’
数据类型不对。
#我原本的代码:
values = values = dataset.values
#改成:
dataset.values.astype('float32') #.astype('float32')转化数据类型
dataset['sub_metering_4'] = ((values[:,0] * 1000 / 60) - (values[:,4] + values[:,5] + values[:,6]))
ufunc ‘isnan’ not supported for the input types, and the inputs could not be
缺失值填充问题:
一开始上网搜索,大家都说是因为行列不对应或者是类型不对应,但是都检查了,并不是。
无意中发现一个回答:将np.isnan改成pd.isna
1、np.isnan(只有数组数值运算时可使用) 注意:numpy模块的isnan方法仅支持对数值进行判断,因此传入的如果是字符串类型会报错
2、is np.nan(不建议使用) 如果我们的空值只会出现由numpy模块的nan,或只想判断由numpy模块生成的nan值,可以使用,但其他场合一律不建议使用 注意:因为math模块同样可以产生nan值,且math.nan由is np.nan判断是False
3、 pd.isna(大部分数据处理的场合推荐使用) 如果我们的空值既会出现np.nan,也会出现math.nan,甚至还会出现None,或者要判断的数据值既可能是数值型也可能是字符串(符合大部分场景的实际情况)
ValueError: array split does not result in an equal division
均分失败的原因
所以,使用split平均切分数组时,如果不能均分会报如下错误:
ValueError: array split does not result in an equal division
此时可用 array_split代替 split
原本代码:
train = np.array(np.split(train, len(train)/7)) # 将数据划分为按周为单位的数据
test = np.array(np.split(test, len(test)/7))
修改后:
train = np.array(np.array_split(train, len(train)/7)) # 将数据划分为按周为单位的数据
test = np.array(np.array_split(test, len(test)/7))