Ich brauche Hilfe die zyklomatische Komplexität des folgenden Codes zu reduzieren:Python: zyklomatische Komplexität reduzieren
def avg_title_vec(record, lookup):
avg_vec = []
word_vectors = []
for tag in record['all_titles']:
titles = clean_token(tag).split()
for word in titles:
if word in lookup.value:
word_vectors.append(lookup.value[word])
if len(word_vectors):
avg_vec = [
float(val) for val in numpy.mean(
numpy.array(word_vectors),
axis=0)]
output = (record['id'],
','.join([str(a) for a in avg_vec]))
return output
Beispiel Eingabe:
record ={'all_titles': ['hello world', 'hi world', 'bye world']}
lookup.value = {'hello': [0.1, 0.2], 'world': [0.2, 0.3], 'bye': [0.9, -0.1]}
def clean_token(input_string):
return input_string.replace("-", " ").replace("/", " ").replace(
":", " ").replace(",", " ").replace(";", " ").replace(
".", " ").replace("(", " ").replace(")", " ").lower()
So werden alle Wörter, die in der lookup.value vorhanden sind Ich nehme den Durchschnitt ihrer Vektorform.
Stört es Sie zu erklären, was der Code an erster Stelle versucht? –
Weitere Details hinzugefügt – futurenext110
Ich habe es von Anfang an versucht, selbst zu programmieren, und ich endete mit dem gleichen Code :) –