python函数已定义但引发NameE

2024-09-30 20:24:47 发布

您现在位置:Python中文网/ 问答频道 /正文

环境: opensuselinux 42.3,python3.4.6,在eclipse下运行

对于自动化测试系统,我从测试用例生成python脚本。 执行脚本时出错

NameError: name 'setVariable' is not defined

生成的脚本导入一个名为testfunc的模块,该模块定义以下函数:

你知道吗测试函数类型地址:

import sys

print("defining 'saveDeviceStatus'")
def saveDeviceStatus(devicePath,fq_fileName):
    print("ssaveDeviceStatus:")
    print("device '%s'" % devicePath)
    print("filePath '%s'" % fq_fileName)

print("defining 'setVariable'")
def setVariable(path,value):
    print("setVariable:")
    print("path '%s'" % path)
    print("value '%s'" % value)

print("defining 'compareDeviceStatus'")
def compareDeviceStatus(device,filename,options):
    print("compareDeviceStatus:")
    print("device '%s'" % device)
    print("filename '%s'" % filename)
    print(options)

print("defining 'checkResults'")
def checkResults(checkList):
    print("checkResults:")
    print(checkList)

生成的脚本如下所示:

图0030图1206图001.py:

#!/usr/bin/python3
#
import time
import os,sys
import importlib.util
spec = importlib.util.spec_from_file_location("testFunctions", "../")
sys.path.append("/home/heinrich/git/swisbox/swibTestPy/pyLib/")
import testfunc

os.chdir('/home/heinrich/git/swisbox/swib61850/test/tryAutomation/nanopi/pilot_dal-static-lib/180525T093506/')
sys.path.append('/home/heinrich/git/swisbox/swibTestPy/src/testlinkFiles/')


# draw actual status
saveDeviceStatus("SWIBCLS1","beforeSwitch_to_1")

checkResults([
    compareDeviceStatus("SWIBCLS1","beforeSwitch_to_1",["nodate"])
    ])

执行脚本输出

$ ./t_0030_1206_001.py 
defining 'saveDeviceStatus'
defining 'setVariable'
defining 'compareDeviceStatus'
defining 'checkResults'
Traceback (most recent call last):
  File "./t_0030_1206_001.py", line 17, in <module>
    saveDeviceStatus("SWIBCLS1","beforeSwitch_to_1")
NameError: name 'saveDeviceStatus' is not defined
$

尽管print语句被执行,(对我来说)表明函数被定义,调用它们会导致错误。我错过了什么?我可以运行哪些其他诊断程序?你知道吗


Tags: pathpyimport脚本valuedevicedefsys
2条回答

这可能有助于:

你知道吗平日地址:

def my_fun():
    print ("Hello, world")

你知道吗主.py地址:

import mod
my_func()

正在执行:

python3 main.py 
Traceback (most recent call last):
  File "main.py", line 3, in <module>
    my_func()
NameError: name 'my_func' is not defined

您可以通过导入函数

from mod import my_fun

或使用:

mod.my_fun()

所以,在您的例子中,使用:testfunc.saveDeviceStatus(..)或使用from testfunc import saveDeviceStatus

首先,这个错误抱怨的是saveDeviceStatus,而不是setVariable。你知道吗

不过,这应该不会让您感到惊讶;您不会在任何地方导入saveDeviceStatus。您要导入testfunc;因此应该通过该名称引用函数。你知道吗

testfunc.saveDeviceStatus("SWIBCLS1","beforeSwitch_to_1")

testfunc.checkResults([
    testfunc.compareDeviceStatus("SWIBCLS1","beforeSwitch_to_1",["nodate"])
])

另外请注意,这是非常不和谐的;您应该使用lower_case_with_underscores作为函数名,而不是camelCase。你知道吗

相关问题 更多 >