尝试通过用户输入关键字“exit”来打破 while 循环。

你好,我正在尝试编写我的第一个程序,只是一个简单的 SQLite 3 程序来熟悉它。首先,该计划的目标是创建一个表来保存考古动物遗骸的基本数据(因为他们对遗骸进行编目的方式是古老的自动取款机)。我的代码中的问题从第 16-35 行开始,我尝试创建一个循环来获取用户输入,然后将该数据插入表/目录中。我试图让程序识别关键字“exit”以退出循环。我一开始尝试使用带有 if & else 语句的 for 循环,但没有成功。我查看了其他几个类似的问题来寻求帮助,我最近的尝试是尝试切换到 while 循环。使用提供的当前代码,输入循环继续进行并忽略关键字“exit”。while input == 'exit'或反之亦然while input != 'exit'。我还尝试导入 sys 并让关键字“exit”使用 sys.exit() ,这只会使程序无法运行(也许我将其放置在循环中太早)。我尝试为 sys.exit() 和 break 定义函数,这也给出了关键字被忽略的相同问题。

(我最初是用pycharm编写的,开始使用Visual Studio,因为社区版pycharm不再包含数据库工具)(正如你所看到的,我的代码是程序性的,我仍在努力对OOP充满信心)(我将数据库放在:内存:在下面的示例中)

先感谢您。如果我没有提供有关我的问题的更简洁的信息,我深表歉意,并且很乐意提供任何其他需要的信息。

import sqlite3


conn = sqlite3.connect(':memory:')

c = conn.cursor()

cursor = conn.cursor()

c.execute("""CREATE TABLE IF NOT EXISTS catalog (

       number integer NOT NULL PRIMARY KEY autoincrement,

       type text NOT NULL,

       taxon text,

       species text NOT NULL,

       part text NOT NULL,

       age integer,

       layer text,

       notes text

       )""")

while True:

if input != 'exit':

    print("Please enter individual specimen data: ")

    c_number = input('Catalog #: ')

    c_type = input('Type of Specimen: ')

    c_taxon = input('Taxon: ')

    c_species = input('Species: ')

    c_part = input('Body Part: ')

    c_age = input('Estimated Age: ')

    c_layer = input('Sedimentary Layer: ')

    c_notes = input('Notes: ')

    cursor.execute("""

        INSERT OR IGNORE INTO catalog(number, type, taxon, species, part, age, layer, notes)

        VALUES (?,?,?,?,?,?,?,?)

        """, (c_number, c_type, c_taxon, c_species, c_part, c_age, c_layer, c_notes))

    conn.commit()

    print('Specimen data entered successfully.')

else:

    if input == 'exit':

        break

c.execute("""CREATE VIEW catalog (

AS

SELECT * FROM catalog;

""")

conn.close()


牧羊人nacy
浏览 161回答 2
2回答

千万里不及你

input是一个函数,返回用户输入的值。if input != 'exit':永远为真,因为input是一个函数,并且永远不会等于 'exit'您需要检查输入的返回值以查看它是否与字符串“exit”匹配。编辑:尝试以下操作- 如果您有更多提示或没有提示,则此选项应该是“可扩展的”。但有很多方法可以实现您想要做的事情。以下只是其中之一。我添加了评论,因为您似乎是 python 新手!import sqlite3conn = sqlite3.connect(':memory:')c = conn.cursor()cursor = conn.cursor()c.execute("""CREATE TABLE IF NOT EXISTS catalog (       number integer NOT NULL PRIMARY KEY autoincrement,       type text NOT NULL,       taxon text,       species text NOT NULL,       part text NOT NULL,       age integer,       layer text,       notes text       )""")while True:      print('Please enter individual specimen data: ')      input_prompts = [        'Catalog #: ',        'Type of Specimen: ',        'Taxon: ',        'Species: ',        'Body Part: ',        'Estimated Age: ',        'Sedimentary Layer: ',        'Notes: '      ]      responses = []      response = ''      for prompt in input_prompts: # loop over our prompts        response = input(prompt)        if response == 'exit':          break # break out of for loop        responses.append(response)            if response == 'exit':        break # break out of while loop      # we do list destructuring below to get the different responses from the list      c_number, c_type, c_taxon, c_species, c_part, c_age, c_layer, c_notes = responses      cursor.execute("""          INSERT OR IGNORE INTO catalog(number, type, taxon, species, part, age, layer, notes)          VALUES (?,?,?,?,?,?,?,?)          """,                     (          c_number,          c_type,          c_taxon,          c_species,          c_part,          c_age,          c_layer,          c_notes,          ))      conn.commit()      responses.clear() # clear our responses, before we start our new while loop iteration      print('Specimen data entered successfully.')c.execute("""CREATE VIEW catalogASSELECT * FROM catalog;""")conn.close()

HUX布斯

如果没有详细介绍您的代码,我相信它会因识别错误而失败?python 要求您在 while 循环内缩进代码,因此它应该如下所示。while True:    if input != 'exit':        print("Please enter individual specimen data: ")        ...第二个问题是您从未创建过该变量input。当你测试时if input == 'exit':它会失败。您需要决定用户在哪一点可以选择键入exit,将其保存到变量中并测试它,大致如下(我调用变量userinput是为了不覆盖input函数):while True:    userinput = input( 'type exit to exit' )    if userinput != 'exit':        print("Please enter individual specimen data: ")        ...
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python