以下是我的代码:import sqlite3 conn = sqlite3.connect('C:\\Users\\Dell\\Desktop\\studentsTXL.db') conn.execute('create table if not exists students (stunum primary key,name,number)') #conn.execute('CREATE TABLE students(stunum INT PRIMARY KEY NOT NULL,name TEXT NOT NULL,number INT NOT NULL);') def add_student(): student_number = int(input('请输入学生学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"insert into sudents (stunum,name,number) values ({student_number},'{name}',{number})") conn.commit() print('学生信息添加成功') def delete_student(): student_number= int(input('请输入要删除的学生学号:')) conn.execute(f"delete from students where stunum={student_number}") conn.commit() print('学生信息删除成功') def modify_student(): student_number = int(input('请输入要修改的学生的学号:')) name = input('请输入学生姓名:') number = int(input('请输入学生电话:')) conn.execute(f"update students set name='{name}', number={number} where stunum={student_number}") conn.commit() print('学生信息修改成功') # 查询学生信息 def query_student(): student_number = int(input('请输入要查询的学生学号:')) cursor = conn.execute(f"select * from students where stunum={student_number}") row = cursor.fetchone() if row is None: print('无学生信息') else: print(f'学生学号:{row[0]},姓名:{row[1]},电话:{row[2]}') # 主程序 while True: print('这是学生信息管理系统') print('1. 添加学生信息') print('2. 删除学生信息') print('3. 修改学生信息') print('4. 查询学生信息') print('5. 退出系统') choice = int(input('请选择要执行的操作:')) if choice == 1: add_student() elif choice == 2: delete_student() elif choice == 3: modify_student() elif choice == 4: query_student() elif choice == 5: break else: print('无此项选择') conn.close(),在运行且输入学生信息后,查询显示无学生信息,请问如何改正
时间: 2024-03-16 09:44:29 浏览: 45
在您的代码中,存在一个拼写错误。在添加学生信息时,您将表名写成了`sudents`而不是正确的`students`。因此,在查询学生信息时会出现错误。将以下代码:
```
conn.execute(f"insert into sudents (stunum,name,number) values ({student_number},'{name}',{number})")
```
更改为:
```
conn.execute(f"insert into students (stunum,name,number) values ({student_number},'{name}',{number})")
```
即可解决该问题。
相关问题
sqlite3中 conn=sqlite3.connect conn.text_factory=str
在SQLite3的Python模块中,可以使用`sqlite3.connect()`方法连接到SQLite数据库,并可以在连接对象上设置一些属性。其中,`text_factory`就是一个属性,用于指定在读取字符串类型数据时应该使用的文本编码格式。
默认情况下,Python的SQLite3模块会尝试使用系统默认的文本编码格式来解码读取的字符串数据。但是,如果数据库中包含非ASCII字符,或者使用了非标准的字符编码,那么读取的字符串数据可能会出现乱码。为了解决这个问题,可以通过设置`text_factory`属性来指定使用的文本编码格式。
以下是一个示例代码,演示如何在连接对象上设置`text_factory`属性:
```python
import sqlite3
conn = sqlite3.connect('example.db')
conn.text_factory = str
```
在这个例子中,我们创建了一个名为example.db的SQLite数据库,并将其连接到Python中的conn变量。然后,我们将`text_factory`属性设置为Python内置的`str`类型,以使用默认的文本编码格式来读取字符串数据。这样,我们就可以在读取字符串数据时避免出现乱码。
conn=sqlite3.connect("C:/Users/L/Desktop/BBS/D1/db.sqlite3")sqlite3.OperationalError: unable to open database file
这个错误通常出现在以下几种情况下:
1. 文件路径错误:请确保文件路径正确,路径中的斜杠应该使用反斜杠。
2. 权限问题:如果您没有访问该文件的权限,就会出现这个错误。请尝试以管理员身份运行您的代码或更改文件权限。
3. 数据库文件已经被打开:如果数据库文件已经被其他程序打开,那么您的代码就无法打开它。请确保关闭其他程序,然后再运行您的代码。
如果以上方法都无法解决您的问题,您可以尝试使用绝对路径来打开数据库文件。例如:
```
import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
conn = sqlite3.connect(os.path.join(BASE_DIR, 'db.sqlite3'))
```
其中,`BASE_DIR` 是您的 Django 项目的根目录。这段代码会将 `db.sqlite3` 文件的绝对路径传递给 `connect()` 方法。
阅读全文