У меня проблема с тем, что у меня есть метод класса, который создает пакетный файл и сохраняет имя файла в переменной с именем «filename». У меня есть другой метод, который запускает пакетный файл, вызывая «имя файла», созданный в другом методе. Но я получаю ответ Класс объекта не имеет атрибута «имя файла». Как я могу создать эту переменную в одном методе и вызвать ее в другом методе в том же классе?
Я попытался установить self.filename = filename. Я попытался установить глобальное имя файла = None вне класса, а затем установить имя файла внутри самого класса init . Я включил следующие фрагменты кода:
class SNMPPage(tk.Frame):
def __init__(self, root=None):
tk.Frame.__init__(self, root)
self.root = root
self.root.title('SNMP Get Set Test')
global filename
self.init_gui()
def create_batch(self):
i = 0
#path = os.getcwd()
global filename
#ping_set = 'ping -n 1 ' + e1.get() + ' | find "TTL=" >null\nif errorlevel 1 (\n echo host not reachable\n pause\n)\n'
snmp_get = 'snmpget' + " -Os" + " -mall " + "-c " + self.e3.get() + ' -v2c' + ' ' + self.e1.get() + ' ' + self.e2.get() + "\n"
snmp_set = 'snmpset' + " -Os" + " -mall " + "-c " + self.e3.get() + ' -v2c' + ' ' + self.e1.get() + ' ' + self.e2.get() + \
' i' + ' 1\n'
timeout = 'timeout ' + self.e4.get() + '\n'
filename = path + '\\SNMPBatchrun' + getdatetime('datetime') + ".bat"
with open(filename, 'w+') as outfile:
while i < 10:
#outfile.write(ping_set)
outfile.write(snmp_get)
outfile.write(snmp_set)
outfile.write(timeout)
i += 1
loggermodule.module_logger.debug('Batch File Created: {}'.format(filename))
logger.debug('Batch file created: {}'.format(filename))
def start_batch(self):
try:
global filename
logger.debug('Starting batch file execution')
loggermodule.module_logger.debug('Starting batch file execution')
#s = subprocess.check_output([filename]).decode('utf-8')
process = subprocess.Popen([filename], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
output, code = process.communicate()
self.root.update()
''' Logger'''
for line in code.decode('utf-8').splitlines():
if 'Waiting for' not in line:
logger.debug(line)
loggermodule.module_logger.debug(line)
for line in output.decode('utf-8').splitlines():
if 'Waiting for' not in line:
logger.debug(line)
loggermodule.module_logger.debug(line)
loggermodule.module_logger.debug("Batch job completed")
logger.debug("Batch job completed")
# with open(log_file, 'w+') as outfile:
# for line in s.splitlines():
# outfile.write(line)
return self.output
except subprocess.CalledProcessError as e:
logger.exception(e)
loggermodule.module_logger.debug(e)
loggermodule.module_logger.debug("There was an error, Batch file stopped. Check Log file")
'SNMPPage' object has no attribute 'filename'
Я ожидаю, что файл будет создан с помощью create_batchfile (что успешно), но затем, когда я запускаю метод start_batchfile, он завершается неудачно с SNMPPageне имеет атрибута "имя файла"