2015-11-06 52 views
0

所以这里是我的问题,我有一个由程序随机生成的字符列表。 我希望每个角色都有对彼此的感受。在列表中生成一个字典

这是到目前为止我的代码:

import random 

# create characters 

class CHARACTER: 
    def __init__(self, name, surname, age, sexe, pragmatism, 
     courage, intelligence, shyness, happiness, fear, hunger, 
     comfort, feeling): 
     self.name = name 
     self.surname = surname 
     self.age = age 
     self.sexe = sexe 
     self.pragmatism = pragmatism 
     self.courage = courage 
     self.intelligence = intelligence 
     self.shyness = shyness 
     self.happiness = happiness 
     self.fear = fear 
     self.hunger = hunger 
     self.comfort = comfort 
     self.feeling = feeling 


characters = [] # list that will contain all the characters 
feelingslist = [] 
sexe = ["Male", "Female"] 

mname = ["John", "Mike", "Albert", "Henry", "Patrick", "Francis", 
"Robert", "Simon", "Charles", "Charlie", "Connor", "Adam", "Blake", 
"Steven", "Edward", "Andrew", "Joe", "Gregory", "Brian", "Anthony", 
"Frank", "Billy", "Boris", "Edgar", "Elliott", "Erik", "Liam", "Kyron", 
"Ned", "Neil", "Ricky", "Ross", "Rich", "Roy", "Preston", "William", 
"Vladimir", "Zach", "Wyatt", "Tylor", "Thomas", "Spike"] 

fname = ["Alessia", "Ally", "Bridgette", "Callie", "Jessica", 
"Debora", "Diana", "Elizabeth", "Clair", "Fran", "Hannah", 
"Helene", "Marie", "Laura", "Leslie", "Leyla", "Kiley", 
"Margaret", "Lola", "Maryjane", "Megan", "Rose", "Sofia", 
"Samantha", "Teresa", "Yolanda", "Teri", "Vicky", "Tricia", 
"Rose", "Rita", "Nita", "Paola", "Penelope", "Polly", 
"Nathalie", "Melody", "Morgane"] 

lname = ["Smith", "Johnson", "Williams", "Jones", "Brown", "Miller", 
"Moore", "Taylor", "Thomas", "White", "Harris", "Thompson", "Garcia", 
"Allen", "Lewis", "Hall", "Young", "Clark", "Hill", "Lopez", "Carter", 
"Turner", "Collins", "Evans", "Campbell", "Nelson", "Parker", "Green", 
"Black", "Green", "Lee", "Martin"] 


# the code below create 10 male and 10 female characters 
# and puts them in the characters list. 


for i in range(20): 
    character = CHARACTER(random.choice(mname), 
    random.choice(lname), random.randint(1,10), 
    random.choice(sexe), random.randint(1,10), random.randint(1,10), 
    random.randint(1,10), random.randint(1,10), 
    random.randint(1,10), random.randint(1,10), 
    random.randint(1,10), random.randint(1,10), {}) 

    characters.append(character) 
    i += 1 

# assigning sexe to characters 

for character in characters: 
    if character.sexe == "Female": 
     character.name = random.choice(fname) 

# feelings 

for character in characters: 
    for character in characters: 
     character.feeling[id(character)] = 5 

# for each character in characters: 
# add one feeling for each character 

# printing characters 

for character in characters: 
    print character.name 
    print character.surname 
    print character.sexe 
    print id(character) 
    print character.feeling 
    print " " 

现在我的这个问题是,该方案只增加了这样每个字符中的一个条目:

莫嘉娜 加西亚 女 { 44880880:5}

因此,每个角色都有自己的“感觉词典”条目,但不适用于其他人。 我想为每个词典在程序中为每一个其他字符都有一个条目(所以每个字符都有关于所有其他字符的意见)

回答

1

在你的循环中设置感受,你正在使用相同的变量character)来控制两个循环;他们需要是不同的变量。

例如:

for char1 in characters: 
    for char2 in characters: 
     char1.feeling[id(char2)] = 5 
-1

所以我应该做这样的事情:

characters_len = len(characters) 

for character in characters: 
    for i in range(characters_len): 
     character.feeling[id(character)] = 5 
     i+=1 

+0

号上:你仍然在用'人物'来识别谁的感觉正在被设定,以及那个感觉是谁。并且不要明确地改变'i'; “for”已经在考虑这一点。 –

+0

好吧,我看到了什么问题,但我不知道如何修复它......你将如何编码它,让程序明白它必须遍历每个字符的所有字符? – Gobhniu

0

好吧,我终于解决了这一点,以防万一有人用同样的问题在这里读出的题目是我的解决方案:

characters_len = len(characters) 

for character in characters: 
    for i in range(characters_len): 
     character.feeling[id(characters[i])] = 5 

谢谢你的答案,并把我在正确的道路