【问题标题】:TypeError: 'NoneType' object is not subscriptable [duplicate]TypeError:“NoneType”对象不可下标[重复]
【发布时间】:2015-02-27 09:09:31
【问题描述】:

错误:names = curfetchone()[0]

TypeError: 'NoneType' object is not subscriptable. 

我尝试检查缩进,但仍然有错误。我读到如果数据库中没有文件名的记录,变量名可能会返回“无”。

我在其他'def'中使用相同的变量'names',它工作正常。我确定这与返回的“无”值有关。

global filename
global t
try:
    con = sqlite3.connect('textdb.db')
    cur = con.cursor()

    filename = tkinter.simpledialog.askstring("Open file...", "Input filename to open:")

    if filename != None:
        cur.execute("SELECT file_name FROM file_info WHERE file_name = ?", (filename,))
        names = cur.fetchone()[0]
        same = str(names)
        if filename == same:
            cur.execute("SELECT file_content FROM file_info WHERE file_name = ?", (filename,))
            content = cur.fetchone()[0]
            t = str(content)
            text.delete(0.0, END)
            text.insert(0.0, t)
        else:
            result = tkinter.messagebox.askyesno(title="File doesn't exist", message="'"+(filename)+"' doesn't exist. Make a new file using '"+(filename)+"'?")
            if result == True:
                cur.execute("SELECT COUNT(*) FROM file_info")
                count_row = cur.fetchone()
                cntdata = count_row[0]
                incr = (cntdata + 1)
                t = str(text.get(0.0, END))
                curtime = str(ctime())
                cur.execute("INSERT OR IGNORE INTO file_info VALUES(?, ?, ?, ?, ?)", (incr, filename, t, curtime, curtime,))
                con.commit()

except sqlite3.Error:
    if con:
        con.rollback()
finally:
    if con:
        con.close()

【问题讨论】:

    标签: python object nonetype


    【解决方案1】:

    如果由于某种原因(空结果集?)curfetchone() 返回None,则[0] 访问当然是被禁止的(正如错误消息中明确指出的那样)。

    所以最好分两步完成

    row = curfetchone()
    if row is not None: 
        names = row[0]
        # proceed
    else:
        # act appropriately
    

    【讨论】:

    • 非常感谢!!!!你的建议对我帮助很大!再次感谢你! :D
    • @AbbyCordovilla 接受答案比使用四个! 符号更感谢:-P
    • @AbbyCordovilla(按问题左侧勾勒出的复选标记接受作品。)
    • 关于什么原因可能导致 fetchone 出现这种行为的任何线索?似乎是一个常见问题,但我看不出明显的原因
    • 非常有帮助
    猜你喜欢
    • 1970-01-01
    • 2021-12-14
    • 2020-11-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-03-11
    • 2021-02-14
    • 2019-08-12
    相关资源
    最近更新 更多