在Python中使用下限和上限替换异常值的函数

from sklearn import datasetsimport pandas as pdimport numpy as npdt = datasets.load_diabetes()data = pd.DataFrame(data= np.c_[dt['data'], dt['target']],columns= dt['feature_names'] + ['target'] )data = data.drop('sex', axis = 1)# 均值加减2倍标准差# 计算变量异常值的函数def out1(x):    mu = np.average(x)    sigma = np.std(x)    LL = mu - 2*sigma # 下限    UL = mu + 2*sigma # 上限    out = [1 if (a >= UL) | (a <= LL) else 0 for a in x]    return(out)# 检查每个变量中的异常值print(data.apply(out1).apply(sum))# 用下限/上限替换异常值的函数def out_impute(x):    mu = np.average(x)    sigma = np.std(x)    LL = mu - 2*sigma # 下限    UL = mu + 2*sigma # 上限    xnew = "Enter Code Here"    return(xnew)data1 = data.apply(out_impute) # 创建包含替换值的新数据

请问有人可以帮助我如何用下限和上限替换异常值吗?

我将异常值定义为 >= mu + 2*sigma 和 <= mu – 2*sigma。我在代码中定义了一个名为’out_impute’的函数,但在替换部分卡住了。

提前感谢!


回答:

使用 df.clip

LL = mu - 2*sigma # 下限 UL = mu + 2*sigma # 上限df['data'].clip(LL, UL)

Related Posts

在使用k近邻算法时,有没有办法获取被使用的“邻居”?

我想找到一种方法来确定在我的knn算法中实际使用了哪些…

Theano在Google Colab上无法启用GPU支持

我在尝试使用Theano库训练一个模型。由于我的电脑内…

准确性评分似乎有误

这里是代码: from sklearn.metrics…

Keras Functional API: “错误检查输入时:期望input_1具有4个维度,但得到形状为(X, Y)的数组”

我在尝试使用Keras的fit_generator来训…

如何使用sklearn.datasets.make_classification在指定范围内生成合成数据?

我想为分类问题创建合成数据。我使用了sklearn.d…

如何处理预测时不在训练集中的标签

已关闭。 此问题与编程或软件开发无关。目前不接受回答。…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注