input("Would you like to read: comedy, political, philisophical, or tragedy?")
a = "comedy"
b = "political"
c = "philisophical"
d = "tragedy"
if a:
input("Would you like the author's nationality to be: English or French?")
e = "French"
d = "English"
if e:
print("Tartuffe")
elif d:
print("Taming of the Shrew")当我运行的时候,程序默认是喜剧性的,然后是Tartuffe。
如何让它识别字符串中的不同类型?
发布于 2012-11-07 11:39:07
您需要存储输入,然后将其与所需内容进行比较,例如:
a = "comedy"
b = "political"
c = "philisophical"
d = "tragedy"
user_input = input("Would you like to read: comedy, political, philisophical, or tragedy?")
if user_input == a:
user_input = input("Would you like the author's nationality to be: English or French?")
if user_input == e:
#do more stuff更好的方法(在我看来)是这样做:
def comedy():
print("comedy")
def political():
print("political")
def philisophical():
print("philisophical")
def tragedy():
print("tragedy")
types = {"comedy":comedy,
"political":political,
"philisophical":philisophical,
"tragedy":tragedy
}
user_input = input()
types[user_input]()因为它更容易管理和读取不同的输入。
发布于 2012-11-07 11:41:57
您只是在测试e的值是否为true (字符串不为null,因此为true)。
您也没有存储输入。
selection = input("Would you like the author's nationality to be: English or French? ")
if selection == e:
print("Tartuffe")
elif selection == d:
print("Taming of the Shrew")发布于 2012-11-07 11:44:16
高度可扩展的代码。
choices = {'e': ('French', 'Tartuffe'), 'd': ('English', 'Taming of the Shrew')}
cstr = ', '.join('%r = %s' % (k, choices[k][0]) for k in sorted(choices))
prompt = 'What would you like the author\'s nationality to be (%s): ' % cstr
i = input(prompt).lower()
print('%s: %s' % choices.get(i, ('Unknown', 'Untitled')))https://stackoverflow.com/questions/13262769
复制相似问题