2014-12-31 14 views
1

Ошибка: names = curfetchone()[0]TypeError: объект «» NoneType не subscriptable

TypeError: 'NoneType' object is not subscriptable. 

Я попытался проверить отступы, но все еще есть ошибка. Я читал, что, возможно, имена переменных возвращают «Нет», если в базе данных нет записи имени файла.

Я использую те же переменные «имена» в другом «def», и он отлично работает. Я уверен, что это связано с возвращаемым значением «Нет».

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() 

ответ

8

Если по какой-либо причине (пустой результат установлен?) curfetchone() возвращает None, [0] доступа, конечно, запрещенный (как сообщение об ошибке ясно говорит).

Так лучше сделать это в два этапа и сделать

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

спасибо большое !!!! ваш совет мне очень помог! еще раз спасибо! : D –

+1

@AbbyCordovilla Принимая ответ, гораздо больше спасибо, чем использование четырех знаков '!': -P – glglgl

+0

@AbbyCordovilla (Принятие работ, нажав на отмеченную галочку слева от вопроса.) – glglgl

Смежные вопросы