Wandering_night 2024-08-18 10:20 采纳率: 47.1%
浏览 2
已结题

异常值处理-拉格朗日插值法

下面是一段拉格朗日插值法解决表格异常值处理的问题。但有几行代码我看不懂,希望有人指点
(代码中加粗、倾斜的部分即是)

import os
import pandas as pd
import numpy as np
from scipy.interpolate import lagrange
import matplotlib.pyplot as plt

plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签

plt.rcParams['axes.unicode_minus']=False #用来正常显示负号

# 数据的读取
data = pd.read_excel('try.xls', header=0)
**_neg_list = ['位移']_**

# 数据的行数
R = data.shape[0]

# 异常数据的个数
for item in neg_list:
    iqr = **_data[item]_**.quantile(0.75) - data[item].quantile(0.25)
    q_abnormal_L = data[item] < data[item].quantile(0.25) - 1.5 * iqr
    q_abnormal_U = data[item] > data[item].quantile(0.75) + 1.5 * iqr
    # print(item + '中有' + str(q_abnormal_L.sum() + q_abnormal_U.sum()) + '个异常值')

# 确定数据上限和下限
for item in neg_list:
    iqr = data[item].quantile(0.75) - data[item].quantile(0.25)
    Too_small = data[item].quantile(0.25) - 1.5 * iqr
    Too_big = data[item].quantile(0.25) + 1.5 * iqr

data**_[u'位移']_**[(data[u'位移']<Too_small) | (data[u'位移']>Too_big)] = None #过滤异常值,将其变为空值

#s为列向量,n为被插值位置,k为取前后的数据个数
def ployinter(s,n,k=5):
    y = s[list(range(n-k,n)) + list(range(n+1,n+1+k))]
    y = y[y.notnull()] #剔除空值
    return lagrange(y.index,list(y))(n)

#逐个元素判断是否需要插值
for i in data.columns:
    for j in range(len(data)):
        if(data[i].isnull())[j]:
            data[i][j] = ployinter(data[i],j)
# print(data[u'位移'])

# 输出拉格朗日插值后的数据
data.to_excel("try_result.xls")

# 把表格列数据调整为arr,arr为修改后的数据
print("拉格朗日插值后的数据:")
d = []
k = 0
while k < R:
    d.append(data[u'位移'][k])
    k +=1
# print(d)
arr = np.array(d)
print(arr)

# 输出图像
x = np.arange(len(d))

plt.plot(x,d,'b-',label="one", marker='*',markersize=4,linewidth=1) # b代表blue颜色  -代表直线

plt.title('位移曲线')

plt.legend(loc='upper left',bbox_to_anchor=(1.0,1.0))

# 直接更改X轴坐标数
# plt.xticks((0,1,2,3,4,5,6,7,8),('0', '1', '2', '3', '4', '5', '6', '7', '8'))

plt.xlabel('时间/h')
plt.ylabel('位移/mm')

#plt.grid(x1)
plt.show()


  • 写回答

2条回答 默认 最新

  • GISer Liu 2024-08-18 10:22
    关注

    该回答引用自GPT-deepseek, 由博主 GISer Liu 编写:

    好的,我们来详细分析并解决您在拉格朗日插值法处理异常值时遇到的问题。我们将逐一解释代码中加粗和倾斜的部分,并提供相应的解决方案。

    1. 加粗和倾斜的部分解释

    1.1 neg_list = ['位移']

    这行代码定义了一个列表 neg_list,其中包含一个元素 '位移'。这个列表用于存储需要处理的列名。

    1.2 data[item]

    在循环中,data[item] 用于访问 DataFrame data 中列名为 item 的列。这里的 itemneg_list 中的元素,即 '位移'。

    1.3 data[u'位移']

    这行代码用于访问 DataFrame data 中列名为 '位移' 的列。注意这里的 u 前缀表示 Unicode 字符串,这在 Python 2 中常见,但在 Python 3 中可以省略。

    2. 代码修改建议

    2.1 修改 neg_list 的定义

    为了代码的可读性和一致性,建议将 neg_list 的定义改为:

    neg_list = ['位移']
    

    2.2 修改异常值处理的代码

    在处理异常值时,建议使用更明确的变量名,并确保代码的可读性。以下是修改后的代码:

    # 确定数据上限和下限
    for item in neg_list:
        iqr = data[item].quantile(0.75) - data[item].quantile(0.25)
        lower_bound = data[item].quantile(0.25) - 1.5 * iqr
        upper_bound = data[item].quantile(0.75) + 1.5 * iqr
    
        # 过滤异常值,将其变为空值
        data[item][(data[item] < lower_bound) | (data[item] > upper_bound)] = None
    

    2.3 修改插值函数的调用

    在插值函数的调用中,确保 data[i].isnull() 的用法正确:

    # 逐个元素判断是否需要插值
    for i in data.columns:
        for j in range(len(data)):
            if pd.isnull(data[i][j]):
                data[i][j] = ployinter(data[i], j)
    

    3. 完整代码

    以下是修改后的完整代码:

    import os
    import pandas as pd
    import numpy as np
    from scipy.interpolate import lagrange
    import matplotlib.pyplot as plt
    
    plt.rcParams['font.sans-serif'] = ['SimHei']  # 用来正常显示中文标签
    plt.rcParams['axes.unicode_minus'] = False  # 用来正常显示负号
    
    # 数据的读取
    data = pd.read_excel('try.xls', header=0)
    neg_list = ['位移']
    
    # 数据的行数
    R = data.shape[0]
    
    # 异常数据的个数
    for item in neg_list:
        iqr = data[item].quantile(0.75) - data[item].quantile(0.25)
        lower_bound = data[item].quantile(0.25) - 1.5 * iqr
        upper_bound = data[item].quantile(0.75) + 1.5 * iqr
        # 过滤异常值,将其变为空值
        data[item][(data[item] < lower_bound) | (data[item] > upper_bound)] = None
    
    # 插值函数
    def ployinter(s, n, k=5):
        y = s[list(range(n-k, n)) + list(range(n+1, n+1+k))]
        y = y[y.notnull()]  # 剔除空值
        return lagrange(y.index, list(y))(n)
    
    # 逐个元素判断是否需要插值
    for i in data.columns:
        for j in range(len(data)):
            if pd.isnull(data[i][j]):
                data[i][j] = ployinter(data[i], j)
    
    # 输出拉格朗日插值后的数据
    data.to_excel("try_result.xls")
    
    # 把表格列数据调整为arr, arr为修改后的数据
    print("拉格朗日插值后的数据:")
    d = []
    k = 0
    while k < R:
        d.append(data['位移'][k])
        k += 1
    arr = np.array(d)
    print(arr)
    
    # 输出图像
    x = np.arange(len(d))
    plt.plot(x, d, 'b-', label="one", marker='*', markersize=4, linewidth=1)  # b代表blue颜色  -代表直线
    plt.title('位移曲线')
    plt.legend(loc='upper left', bbox_to_anchor=(1.0, 1.0))
    plt.xlabel('时间/h')
    plt.ylabel('位移/mm')
    plt.show()
    

    4. 总结

    通过以上修改,代码的可读性和一致性得到了提升。希望这些修改能帮助您更好地理解和使用拉格朗日插值法处理异常值。如果有任何其他问题,欢迎继续提问。

    如果该回答解决了您的问题,请采纳!如果没有,请私信联系或评论您的疑惑

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月26日
  • 已采纳回答 8月18日
  • 创建了问题 8月18日