On Tue, Feb 24, 2009 at 8:03 PM, nathan virgil <sdragon1...@gmail.com> wrote: > I'm experimenting with OOP using the Critter Caretaker script from Python > Programming for the Absolute Beginner as my basis. I've noticed that a > dictionary/function combo is a great way to handle menus, and so I've > adapted the menu to read as: > > > selection = raw_input("Choice: ") > choices = {"0":quit, "1":crit.talk, "2":crit.eat, "3":crit.play} > choice = choices[selection] > choice() > > so that I can call methods from a dictionary, instead of having an > excruciatingly long if structure. Unfortunately, the problem I'm running > into with this is that I can't pass any perimeters through the dictionary. I > can't figure out how, for example, I could have an option that calls > crit.eat(2) and another that calls crit.eat(4). The only thing I can think > of is going back to the if structure, but my instinct tells me that this is > a Bad Idea. What can I do?
You could use a tuple, consisting of the function and its parameter: choices = {"0": (quit,), "1": (eat,2), "2": (eat,4)} choice = choices[selection] choice[0](*choice[1:]) But as said by someone else, if the choices are the lowest n natural numbers, a list feels more natural: choices = [(quit,), (eat,2), (eat,4)] choices = choice[int(selection)] choice[0](*choice[1:]) -- André Engels, andreeng...@gmail.com _______________________________________________ Tutor maillist - Tutor@python.org http://mail.python.org/mailman/listinfo/tutor