gpt4 book ai didi

python - Python中实例方法使用情况的跟踪/记录

转载 作者:太空宇宙 更新时间:2023-11-03 14:05:16 24 4
gpt4 key购买 nike

我正在开发一个子程序,可以帮助我学习英语。

我在class System中开发了一些方法,它们是基于爬虫的target_word查找器的示例/语义。

然后我通过class User生成了一个用户,它生成一个实例并继承class System中的每个方法。

然后我想做的是,每当用户使用继承到 User 类 的方法时,它都会跟踪该方法用于哪个单词,并将该信息记录在 list = [ ] 作为 sheudo 数据库

class System:
def wik_sem(self, target_word):
print("start searching for the target_word {}\n".format(target_word))
driver.get("https://en.wiktionary.org/wiki/" + target_word) #open the page of chronological page
elem_info =[]
for i in range(0, 20): #20 is the assumed maximum number of li[]
try:
element = '//*[@id="mw-content-text"]/div/ol[1]/li['+str(i)+"]"
elem_info.append(driver.find_elements_by_xpath(element))
except:
break
reference_wik = []
for i in range(0, len(elem_info)):
if elem_info[i] == []:
pass
else:
reference_wik.append((elem_info[i][0].text).split("\n")[0].split())
#simple_parser


# remove 'qutations','▼'
for i in range(0,len(reference_wik)):
if '▼' in reference_wik[i]:
del reference_wik[i][(len(reference_wik[i])-1)] #use del twice to delete both of '▼' and 'quotations'
del reference_wik[i][(len(reference_wik[i])-1)] #use del to remove an element in list with index
#remove the first parenthesized element, e.g. (countable) 'the thing which can be counted' ...
for i in range(0,len(reference_wik)):
if '(' in list(reference_wik[i][0]):
del reference_wik[i][0] #use del to remove an element in list with index
#remove '.' at the end of each definition
for i in range(0,len(reference_wik)):
if '.' in list(reference_wik[i][-1]):
reference_wik[i][-1] = reference_wik[i][-1].replace(".", "")
print("Definition of {} from wiktionary.org".format(target_word))
for i in range(len(elem_info)):
try:
print(elem_info[i][0].text)
except:
pass

return reference_wik

def wis(self, target_word):
driver.get("https://wordsinasentence.com/" + target_word+ "-in-a-sentence/") #open the page of chronological page
sentence_numb = 20
for i in range(1, sentence_numb):
try:
elem_info = driver.find_element_by_xpath('//*[@id="content"]/p[{}]'.format(i))
if 'WATCH' in elem_info.text.split():
break
print(elem_info.text+"\n")
except:
pass

def finder(self, target_word):
reference_wik = wik_sem(target_word)
print('\n\n')
wis(target_word)
return reference_wik

def ety(self, target_word):
print("start searching for the etymology of the target_word {}\n".format(target_word))
driver.get("https://en.wiktionary.org/wiki/" + target_word)
elem_info = driver.find_element_by_xpath('//*[@id="mw-content-text"]/div/p[3]')
return elem_info.text
<小时/>
class User(System):
def __init__(self, id_ = None):
super().__init__()
id_ = uuid4()
self.id = id_
self.hist = []
<小时/>
yoon = User() #class instantiation
yoon.finder('eschew')
<小时/>

然后将“eschew”附加到 yoon.hist_list -> 我该怎么做?

最佳答案

看起来您想要的是将属性 hist 添加到父类 System 而不是子 User 中,然后将 reference_wik 附加到方法 finder 中的列表 self.hist,而不是返回它:

class System():

def __init__(self):
self.hist = []

#def wik_sem, wis ...

def finder(self,target_word):
reference_wik = wik_sem(target_word)
print('\n\n')
wis(target_word)
self.hist.append(reference_wik)


#rest of System def...

然后User可以定义为

class User(System):
def __init__(self):
super().__init__()
id_ = uuid4()
self.id = id_

然后

yoon = User()
yoon.finder('eschew')
print(yoon.hist)

产量:

#...output from print calls within finder...
['eschew']

关于python - Python中实例方法使用情况的跟踪/记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48943029/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com