【问题标题】:Error despite Global keyword being used to access variable inside function尽管使用全局关键字访问函数内的变量,但仍出错
【发布时间】:2024-05-23 09:00:02
【问题描述】:

我创建了几个全局变量,如下面的代码所示。但是,当我尝试在各个函数中使用它们时,我仍然会遇到同样的错误。

请在下面找到我的代码

def create_df():
  global sheet_name, sheet_df 
  for s in sheets:
     sheet_name = s
     sheet_df = pd.read_excel(xls, sheet_name=s)
     sheet_df = sheet_df[sheet_df.columns.difference(sheet_df.filter(like='Derived').columns,sort=False)]
     print("Sheet " + str(s) + " is created as a dataframe successfully")
     transform_stage_1_df()

def transform_stage_1_df():
    global sheet_df 
    sheet_df = pd.melt(sheet_df, id_vars='subject_ID', var_name='headers', value_name='dates')
    sheet_df['header_extracted'] = [x.split("Date")[0] for x in sheet_df['headers']]
    sheet_df['day'] = sheet_df['header_extracted'].str.extract('(\d+)', expand=True).astype(int)
    sheet_df = sheet_df[sheet_df.groupby(['subject_ID','header_extracted'])['dates'].transform('count').ne(0)].copy()
    sheet_df = sheet_df.sort_values(by=['subject_ID','day'])
    sheet_df.drop(['header_extracted', 'day'], axis=1, inplace=True)
print("Stage 1 transformation is complete")


if __name__ == '__main__':
    print("Execution Started")
    print("File read successfully")
    sheets = xls.sheet_names
    sheet_name = sheet_df = Non_Cholesterol = None
    dataFramesDict = dict()
    create_df()
    add_units()
    Non_Cholesterol.to_csv('Output.csv')

根据 SO 帖子,我已经更新了全局关键字,但我仍然得到 UnboundLocalError: local variable 'sheet_df' referenced before assignment

UnboundLocalError                         Traceback (most recent call last)
 <ipython-input-210-dc2f8412235d> in <module>
      7     sheet_df = None
       8     dataFramesDict = dict()
  ----> 9     create_df()
 10     Non_Cholesterol.to_csv('C:\\Users' + 
 str('Non_cholesterol.csv'),index=None)
 11     print("Export successful")

 <ipython-input-205-c93604f0da4f> in create_df()
  5         sheet_df =sheet_df[sheet_df.columns.difference(sheet_df.filter(like='Derived').columns,sort=False)]
  6         print("Sheet " + str(s) + " is created as a dataframe 
  successfully")
     ----> 7         transform_stage_1_df()

 <ipython-input-206-b59c70018a9b> in transform_stage_1_df()
  1 def transform_stage_1_df():
  ----> 2     sheet_df = pd.melt(sheet_df, id_vars='subject_ID', 
 var_name='headers', value_name='dates')
  3     sheet_df['header_extracted'] = [x.split("Date")[0] for x in 
 sheet_df['headers']]
  4     sheet_df['day'] = sheet_df['header_extracted'].str.extract('(\d+)', 
 expand=True).astype(int)
  5     sheet_df = 
 sheet_df[sheet_df.groupby(['subject_ID','header_extracted']) 
 ['dates'].transform('count').ne(0)].copy()

  UnboundLocalError: local variable 'sheet_df' referenced before assignment

【问题讨论】:

  • 你把全局放错地方了,需要在函数里做全局
  • 你的意思是无论我在哪里使用变量,我都必须在任何地方使用global?我的意思是在它被使用的任何功能中一次?
  • 在每个函数的顶部声明一次您希望作为全局变量存在的变量。我想指出这是一种非常糟糕的编程习惯,除非你有一些非常特殊的需要,否则不要这样做
  • 不,仍然是同样的错误。请查看更新后的代码
  • 两者都有。通常尽量避免使用全局变量,因为这会很快使代码无法维护。让您的函数返回它们更改的内容,或传递可变参数以供更改

标签: python python-3.x pandas scope global-variables


【解决方案1】:

您需要在脚本主体中初始化变量。当您说global variable_name 时,这意味着您将访问函数外部的变量,而不是名为variable_name 的局部变量。

# Initialize the variables first
sheet_name = None
sheet_df = None

def create_df():
  global sheet_name, sheet_df 
  for s in sheets:
     sheet_name = s
     sheet_df = pd.read_excel(xls, sheet_name=s)
     sheet_df = sheet_df[sheet_df.columns.difference(sheet_df.filter(like='Derived').columns,sort=False)]
     print("Sheet " + str(s) + " is created as a dataframe successfully")
     transform_stage_1_df()

def transform_stage_1_df():
    global sheet_df 
    sheet_df = pd.melt(sheet_df, id_vars='subject_ID', var_name='headers', value_name='dates')
    sheet_df['header_extracted'] = [x.split("Date")[0] for x in sheet_df['headers']]
    sheet_df['day'] = sheet_df['header_extracted'].str.extract('(\d+)', expand=True).astype(int)
    sheet_df = sheet_df[sheet_df.groupby(['subject_ID','header_extracted'])['dates'].transform('count').ne(0)].copy()
    sheet_df = sheet_df.sort_values(by=['subject_ID','day'])
    sheet_df.drop(['header_extracted', 'day'], axis=1, inplace=True)
    print("Stage 1 transformation is complete")


if __name__ == '__main__':
   print("Execution Started")
   xls = pd.ExcelFile('C:\\Users\\All.xlsx')
   print("File read successfully")
   sheets = xls.sheet_names
   dataFramesDict = dict()
   create_df()

【讨论】:

  • 您能否评论完整的错误以及它抛出的哪一行?很遗憾,我无法访问该图像。
  • 现已更新。请检查
  • 它应该可以工作,如果它这样说的话。我想你可能正在调用一个包含 main 代码的函数。我的错误。
最近更新 更多