python sqlite3 fetchall_使用python sqlite3的fetchall无法显示结果?

1.问题描述:使用python for语句循环插入数据到数据库(sqlite3),然后使用select * from tabname 然后用fetchall得到所有结果,结果为空,但是将数据表放到linux下用sqlite3打开然后.du就能看的插入的所有数据,望大神讲解~

代码:

--coding:gb2312--

import xlrd

import os

import sys

global strall

import sqlite3

import pprint

strall = None

def get_xlsx():

stdi,stdo,stde=sys.stdin,sys.stdout,sys.stderr

reload(sys)

sys.stdin,sys.stdout,sys.stderr=stdi,stdo,stde

sys.setdefaultencoding('gb2312')

xlrd.Book.encoding = "gb2312"

xlsx = xlrd.open_workbook(r'f:\20170809_mailbox.xlsx')

print xlsx.sheet_names()

print type(xlsx.sheet_names())

sheet = xlsx.sheet_by_name('Sheet1')

print sheet.nrows,sheet.ncols

row_name_data = sheet.row_values(0)

list1 = []

user_data = []

for numc in range(1,int(sheet.nrows)):

data = sheet.row_values(numc)

temp_data = []

for temp in range(len(data)):

data_to_unicode = unicode(data[temp])

temp_data.append(data_to_unicode)

user_data.append(temp_data)

conn = sqlite3.connect(r'f:\sec2.db')

cur = conn.cursor()

conn.execute('''

CREATE TABLE user_info(

user_id INTEGER DEFAULT 0 PRIMARY KEY ,

user_number INTEGER DEFAULT 0 UNIQUE,

user_name VARCHAR(15),

user_type VARCHAR(15),

user_system VARCHAR(15),

user_group VARCHAR(30),

first_group VARCHAR(30),

second_group VARCHAR(30),

user_company VARCHAR(30),

work_mail_vc VARCHAR(30),

work_mail_vcc VARCHAR(30),

work_mail_v VARCHAR(30),

work_mail_lds VARCHAR(30),

work_mail_hzhz VARCHAR(30),

work_mail_un VARCHAR(30)

)

''')

query = 'INSERT INTO user_info VALUES (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)'

for q in range(len(user_data)):

print '#########'

#print user_data[q][2]

conn.execute(query,(user_data[q][0],user_data[q][1],user_data[q][2],user_data[q][3],user_data[q][4],user_data[q][5],user_data[q][6],user_data[q][7],user_data[q][8],user_data[q][9],user_data[q][10],user_data[q][11],user_data[q][12],user_data[q][13],user_data[q][14]))

conn.commit()

conn.execute('SELECT * FROM user_info')

#cur.execute("SELECT tbl_name FROM sqlite_master WHERE type='table'")

result = cur.fetchall()

pprint.pprint(result)

conn.close()

if name == '__main__':

get_xlsx()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值