python - Jupyter Notebook 不记得我在上面的单元格中创建的变量

标签 python python-3.x jupyter-notebook global-variables local

当我运行我的代码时出现错误:

NameError: name 'df_test' is not defined

我在另一台计算机上没有出现此错误,但在我的新计算机上出现了。我认为这与全局变量和局部变量有关,但这很奇怪,因为在第二个单元格中创建的变量实际上在第三个单元格中使用,问题出现在第四个单元格中。

我试过声明全局,然后是第一个单元格中的变量,这是行不通的。在第三个单元格中执行此操作确实有效。但我不想继续这样做,因为我从我的另一台电脑上知道这是不正常的。

### cell 1
    import pandas as pd
    import numpy as np
    from sklearn.model_selection import train_test_split,cross_val_score,ShuffleSplit  
    import os
    import scipy

### cell 2
    df=pd.read_csv("pandas2.txt",sep=';').drop('listened',axis=1).drop('Usercount',1)
    temp_u=df['User'].unique()
    temp_s=df['Song'].unique()
    avg=df['rating'].mean()
### cell 3
    lamda=0.05
    gamma=0.04
    m=128
    splits=20
    df_train,df_test=train_test_split(df,test_size=0.1, random_state=1)
    beta_u=pd.DataFrame(temp_u,columns=['User'])
    beta_s=pd.DataFrame(temp_s,columns=['Song'])
    beta_u['beta_u']=0
    beta_s['beta_s']=0
    for chunk in np.array_split(df_train, splits):
        x=chunk.merge(beta_u, on='User',how='left').merge(beta_s,on='Song',how='left')

        x['pred']=avg+x['beta_u']+x['beta_s']+(x[pnames]*x[qnames]).sum(axis=1)
        x['gradu']=gamma*(x['rating']-x['pred']-lamda*x['beta_u'])
        beta_u=beta_u.merge(x[['User','gradu']].groupby('User').mean(),on='User',how="left").groupby('User').mean().fillna(0)
        beta_u['beta_u']+=beta_u['gradu']
        beta_u=beta_u.drop(['gradu'],axis=1)
        x['grads']=gamma*(x['rating']-x['pred']-lamda*x['beta_s'])
        beta_s=beta_s.merge(x[['Song','grads']].groupby('Song').mean(),on='Song',how="left").fillna(0)
        beta_s['beta_s']+=beta_s['grads']
        beta_s=beta_s.drop(['grads'],axis=1)


        x[pgrad]=(x[qnames].multiply(x['rating']-x['pred'], axis="index")+np.array(x[qnames]**2)*np.array(x[pnames]))#.divide((x[qnames]*x[qnames]).sum(axis=1),axis=0)
        beta_u=beta_u.merge(x[['User']+pgrad].groupby('User').mean(),on='User',how="left").fillna(0)
        beta_u[pnames]=beta_u[pgrad]#np.array(beta_u[pnames])+np.array(beta_u[pgrad])
        beta_u[pnames]=np.where(beta_u[pnames]>0,beta_u[pnames],10**(-6))
        beta_u=beta_u.drop(pgrad,1)


        x[qgrad]=(x[pnames].multiply(x['rating']-x['pred'], axis="index")+np.array(x[pnames]**2)*np.array(x[qnames]))#.divide((x[pnames]*x[pnames]).sum(axis=1),axis=0)
        beta_s=beta_s.merge(x[['Song']+qgrad].groupby('Song').mean(),on='Song',how="left").fillna(0)
        beta_s[qnames]=beta_s[qgrad]#np.array(beta_s[qnames])+np.array(beta_s[qgrad])
        beta_s[qnames]=np.where(beta_s[qnames]>0,beta_s[qnames],10**(-6))
        beta_s=beta_s.drop(qgrad,1)
    x=df_test.merge(beta_u, on='User',how='left').merge(beta_s,on='Song',how='left').fillna(0)
    x['pred']=x['beta_u']+x['beta_s']+avg+(np.array(x[pnames])*np.array(x[qnames])).sum(axis=1)
    x['pred2']=np.where(x['pred']>0.5,1,0)
    RMSE=np.mean((x['rating']-x['pred'])**2)
    RMSE2=np.mean((x['rating']-x['pred2'])**2)
    print(RMSE)
    print(RMSE2)
### cell 4
    t=len(df_test)
    sim_Song=pd.DataFrame(scipy.sparse.load_npz('simUser.npz').todense())
    sim_Song.index=pd.read_csv('Itemnames.csv',sep=';')['Song']
    sim_Song.columns=pd.read_csv('Itemnames.csv',sep=';')['Song']
    beta_s=beta_s.set_index('Song')

NameError: name 'df_test' is not defined

global df_train, df_test, df, x, beta_s, beta_u 放在单元格 3 的顶部时,它工作正常

最佳答案

问题出在 %%time 上。如果我突然删除它,一切正常。

关于python - Jupyter Notebook 不记得我在上面的单元格中创建的变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56627032/

相关文章:

python - 如何在for循环中用空格分隔值

python - 如何从 tkinter 的网格中删除小部件?

mysql - 在 Jupyter 笔记本、Conda 环境、Python 3.6 上找不到 MySQL

python - VS Code 启动命令行参数来更改扩展参数

python-3.x - 安装 Jupyter 扩展,启用失败 'nbextension'

python - Python 字典是否是与 Rexx 复合变量等效的数据结构?

python - 将 python requests 程序转换为对curl的调用

python - 使用 Python 在有限大小的图像中查找未填充的圆圈

python - 如何从按 groupby 排列的组中创建数据框?

python - 使 python 3 异常向后兼容