Python中文
首页
教程
问答
标签
搜索
登录
注册
Python:“非类型”对象不可下标”错误
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<div> </div> <p>我不熟悉Python中的数据库,因此为了练习一些关键技能,我正在构建一个登录屏幕,将用户名和哈希密码写入数据库,然后根据数据库中的内容检查用户的输入。然而,当试图从数据库中提取用户名和密码并将它们存储在变量中时,我不断得到“'NoneType'对象不可订阅”错误</p> <p>我怎样才能解决这个问题</p> <p>这是我的程序中包含错误的函数</p> <pre><code>def login(): usernameAttempt = input("Enter your username: ") passwordAttempt = input("Enter your password: ") usernameSql = """SELECT Username FROM Details WHERE Password = '%s'""" % (passwordAttempt) # Selecting username in database cur.execute(usernameSql) usernameSql = cur.fetchone() userFetched = usernameSql[0] # Pulling the item from the database passwordSql = """SELECT Password FROM Details WHERE Username = '%s'""" % (usernameAttempt) cur.execute(passwordSql) passwordSql = cur.fetchone() passFetched = passwordSql[0] dbPassword, dbSalt = passFetched.split(":") return dbPassword, dbSalt, passwordAttempt, usernameAttempt, userFetched, passFetched </code></pre> <p>我希望userFetched和passFetched变量被分配到username和password列中索引0处的值,但错误消息如下:</p> <p>回溯(最近一次呼叫最后一次):</p> <p>文件“C:\Users\laure\Documents\Login screen.py”,第57行,在 dbPassword、dbSalt、passwordtrunt、usernametrupt、userFetched、passFetched=login()</p> <p>文件“C:\Users\laure\Documents\Login screen.py”,第34行,登录 userFetched=usernameSql[0]#从数据库中提取项目 TypeError:“非类型”对象不可下标</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您的<code>select Username</code>查询没有返回任何行。因此,结果集是空的,并且没有要获取的内容。因此<code>fetchone</code>调用返回的是<code>None</code>,而不是您期望的行元组</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
4 回答
尽管python中的表达式为false,但循环仍在运行
7 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
7 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
9 回答
尽管python字典包含了大量的条目,但它并没有增长
8 回答
尽管python说模块存在,为什么我会得到这个消息?
2 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
3 回答
尽管stdout和stderr重定向,但未捕获错误消息
1 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
3 回答
尽管tkinter上的变量已更改,但显示未更改
5 回答
尽管try/except使用Python进行单元测试时出现断言错误
1 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
7 回答
尽管url有效,Pandas仍读取url的\u csv错误
5 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
1 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
2 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
3 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
1 回答
尽管下载了i,但找不到型号“fr”
9 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
6 回答
尽管为所有行指定了权重,网格(0)仍不起作用
8 回答