如何从代码中删除RunTimeWarning错误?

Ada*_*dam 3 python numpy compiler-warnings linear-regression spyder

RuntimeWarning当我在最底层运行回归代码时,我不断得到.我不知道如何修复它们.我相信它可能是attencoef列表,因为它有一些nan值.有什么建议?

这些是我得到的错误:

C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_stats_mstats_common.py:106: RuntimeWarning: invalid value encountered in double_scalars
  slope = r_num / ssxm
C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_stats_mstats_common.py:116: RuntimeWarning: invalid value encountered in sqrt
  t = r * np.sqrt(df / ((1.0 - r + TINY)*(1.0 + r + TINY)))
C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_distn_infrastructure.py:879: RuntimeWarning: invalid value encountered in greater
  return (self.a < x) & (x < self.b)
C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_distn_infrastructure.py:879: RuntimeWarning: invalid value encountered in less
  return (self.a < x) & (x < self.b)
C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_distn_infrastructure.py:1818: RuntimeWarning: invalid value encountered in less_equal
  cond2 = cond0 & (x <= self.a)
C:\Users\MTM User\Anaconda3\lib\site-packages\scipy\stats\_stats_mstats_common.py:118: RuntimeWarning: invalid value encountered in double_scalars
  sterrest = np.sqrt((1 - r**2) * ssym / ssxm / df)
Run Code Online (Sandbox Code Playgroud)

代码:

for depthvalues in split_depth.values(): # only takes the values (separated lists), removes keys

    # takes into account the number of yows
    count+=1

    depthlst = depthvalues
    depthfirst = depthlst[0] #find my first depth or deepest depth
    depthlast = depthlst[-1] # find my last depth, or shallowest

    depthfirst_index = depth.index(depthfirst) #finds the index of my deepest depth for this segment in the filtered lists
    depthlast_index = depth.index(depthlast) #finds the index of my shallowest depth for this segment in the filtered lists

    irradlst = irrad[depthfirst_index:depthlast_index+1]

    irrad_first = irradlst[0] #finds the corresponding irradiance
    irrad_last = irradlst[-1] 
    irrad_last = float(irrad_last)

    irradlst = np.array(irradlst).astype(np.float)
    depthlst = np.array(depthlst).astype(np.float)

    attencoef = [np.log(i/irrad_last) for i in irradlst]

    #whenever I use this line of code(below) I get a bunch of errors
    regress = linregress(attencoef,depthlst) 
Run Code Online (Sandbox Code Playgroud)

Dar*_*nus 6

您应该使用以下命令过滤警告:

import warnings
warnings.filterwarnings("ignore", category=RuntimeWarning) 
Run Code Online (Sandbox Code Playgroud)

category是你要沉默的警告类型.

  • 这就是问题的标题所问的......但是,是的,最好首先看看*为什么*你会首先得到“RuntimeWarning”以防止它们出现。 (3认同)