python 做一个图书管理系统,数据库:sqlite

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python 做一个图书管理系统,数据库:sqlite相关的知识,希望对你有一定的参考价值。

通过输入书名,查找book_id,book_id为自动增加。
def bor():
book_name=raw_input('请输入要借的书名:')
if book_name.strip()=='':
print u'书名不能为空'
return bor()
else :
sql=''' select book_id from Book where book_name='%s' '''%book_name
cur.execute(sql)
book=cur.fetchall()
book1=book[0][0]
a='%d' %book1
print a
a='a'
if a.isdigit():
b=int(a)
else:
b='123'
print b
#print "".join(book[0])
if book :
account=raw_input('请输入账号:')
if account.strip()=='':
print '账号不能为空!!!'
else :
sqll="select user_id from User where account='%s'"%account
cur.execute(sqll)
acc=cur.fetchall()
acc1=acc[0][0]
b='%d'%acc1
print b
if acc1:
#borrow_date='20200303'
sqlll='''insert into Borrow(book_id,user_id)
values(?,?)''' , (a,b)
cur.execute(sqlll)
con.commit()
cur.execute('select* from Borrow')
print cur.fetchall()
print '借书成功!!!'
else:
print u'不存在%s这个账号!!!'%account
else:
print u'不存在%s这本书!!!'%book_name

天提示的错误为:
operation parameter must be str or unicode

字符集的问题啊,数据库里面应该默认是UTF8编码。你输入的参数有中文,最好转换为UTF8,你查查PYTHON 字符集。
不同字符集环境下运行结果不同,建议参考:http://blog.csdn.net/a285699732/article/details/7679293
建议SQL用LIKE,有时候输入多了空格查不到的,去除空格后查询。追问

前面都能执行,执行到
sqlll='''insert into Borrow(book_id,user_id)
values(?,?)''' , (a,b)
cur.execute(sqlll)
出的错,获取的book_id,user_id都为字符型的数字,
参数不涉及中文啊

追答

self.cur.execute(("insert into BasicInfo(ID,PRO_NAME,COMP_NAME,HREF,TIME)values ('%i','%s','%s','%s',datetime('%s'))"%(id, pro_name, comp_name,href,time )))
我以前的一段代码,可以参考下。

字符串赋值方式不对。
str = "values(%d,%d) "%(a,b).

追问

灰常感谢,最后写成这样‘%s’就好了,

参考技术A 好像是sql拼接的问题 把sql打印出来 直接到数据库执行 看看是哪里有问题 参考技术B 怎么用套用set,fet函数建立图书馆借书还书的程序呢?求大神帮忙

以上是关于python 做一个图书管理系统,数据库:sqlite的主要内容,如果未能解决你的问题,请参考以下文章

SQL注入练习平台sqli-labs

我想做一个简单的图书管理系统,如何快速导入所需数据?

Django-图书管理系统(含源码)

如何用java连接数据库做图书管理系统

Django图书管理系统(单表操作)

Django——图书管理系统