python 做一个图书管理系统,数据库:sqlite
通过输入书名,查找book_id,book_id为自动增加。defbor():book_name=raw_input('请输入要借的书名:')ifbook_name.st...
通过输入书名,查找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 展开
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 展开
3个回答
展开全部
字符集的问题啊,数据库里面应该默认是UTF8编码。你输入的参数有中文,最好转换为UTF8,你查查PYTHON 字符集。
不同字符集环境下运行结果不同,建议参考:http://blog.csdn.net/a285699732/article/details/7679293
建议SQL用LIKE,有时候输入多了空格查不到的,去除空格后查询。
不同字符集环境下运行结果不同,建议参考: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).
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询