Я пытаюсь работать с классами, но все еще плохо знаком с ними.Я не понимаю, как наследовать атрибуты родительского класса, а также инициализировать новые атрибуты дочернего класса.Я считаю, что родительские атрибуты могут вызываться, но не дочерние атрибуты, которые я определяю.Пожалуйста, смотрите мой код ниже:
import random
import hashlib
import base64
import requests
import json
import urllib3
import getpass
# Disable warning re: server certificate checking turned off
urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
class vsa:
def __init__(self):
self.vsa_token = self.api_authentication()
self.headers = {'Authorization': "Bearer " + self.vsa_token}
self.url = "example.com"
def api_authentication(self):
while True:
username = input("Enter your username: ")
password = getpass.getpass("Enter your password: ")
vsa = "example.com/api/auth"
random_integer = random.randint(5000, 50000)
CoveredSHA256HashTemp_object = hashlib.sha256()
CoveredSHA256HashTemp_object.update(('%s%s' % (password, username)).encode('utf-8'))
CoveredSHA256HashTemp = CoveredSHA256HashTemp_object.hexdigest()
CoveredSHA256Hash_object = hashlib.sha256()
CoveredSHA256Hash_object.update(('%s%d' % (CoveredSHA256HashTemp, random_integer)).encode('utf-8'))
CoveredSHA256Hash = CoveredSHA256Hash_object.hexdigest()
CoveredSHA1HashTemp_object = hashlib.sha1()
CoveredSHA1HashTemp_object.update(('%s%s' % (password, username)).encode('utf-8'))
CoveredSHA1HashTemp = CoveredSHA1HashTemp_object.hexdigest()
CoveredSHA1Hash_object = hashlib.sha1()
CoveredSHA1Hash_object.update(('%s%d' % (CoveredSHA1HashTemp, random_integer)).encode('utf-8'))
CoveredSHA1Hash = CoveredSHA1Hash_object.hexdigest()
auth = "user=%s, pass2=%s, pass1=%s, rpass2=%s, rpass1=%s, rand2=%d, twofapass=:undefined" % (username, CoveredSHA256Hash, CoveredSHA1Hash, CoveredSHA1Hash, CoveredSHA256Hash, random_integer)
encode = base64.urlsafe_b64encode(('%s' % auth).encode('UTF-8')).decode('ascii')
headers = { 'Authorization' : 'Basic %s' % encode }
r = requests.get(vsa, headers=headers, verify=False)
data = r.text
parsed_data = json.loads(data)
if parsed_data['ResponseCode'] == 0:
print("\nVSA token successfully retrieved\n")
vsa_token = parsed_data['Result']['Token']
return vsa_token
else:
print("Unauthorized")
def get_vsa_token(self):
return self.vsa_token
class agents(vsa):
def __init___(self):
vsa.__init__(self)
self.call = "/asetmgmt/agents"
def get_agents(self):
list_agents = []
r = requests.get(self.url + self.call, headers=self.headers, verify=False)
data = r.text
parsed_data = json.loads(data)
all_agents = parsed_data
for agents in all_agents['Result']:
list_agents.append((agents['AgentName']))
return list_agents
session = agents()
print(session.call)
Последняя команда - print(session.call)
дает мне следующий вывод:
AttributeError: 'agents' object has no attribute 'call'
Тем не менее, я принял (что я считаю)Соответствующие фрагменты этого кода и запустить его через PythonTutor, и увидеть, что атрибут вызова инициализируется?
PythonTutor Ссылка на код
Я в растерянности для чегоЯ делаю не такЯ обнаружил, что могу инициализировать переменную вне блока agents.__init__(self)
, и это прекрасно работает:
class agents(vsa):
call = "/assetmgmt/agents"
def __init___(self):
vsa.__init__(self)
, но теперь это что-то концептуальное, что беспокоит меня.Я глуп в том, как я это структурирую?Как бы вы лучше структурировали?
Спасибо за любые идеи, которые вы можете предоставить.