鱼C论坛

 找回密码
 立即注册
查看: 693|回复: 4

[已解决]求教下,python把execl表导入到mysql为什么这么慢?

[复制链接]
发表于 2020-5-8 15:46:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
3000多条数据要花半分钟,机子差一点要花1,2分钟,怎么解决?
def excelTosql():
    global photo_repository
    if (len(photo_repository) == 0):
        tk.messagebox.showinfo("警告", "先选择照片所在的文件夹!")
        return
    file=tkinter.filedialog.askopenfilename()
    if file[-4:]!='.xls':
        tkinter.messagebox.showerror('错误','您选择的不是excel文件')
        return
    temp=file.split('/')
    global datatable_name
    tablename=temp[-1][0:-4]
    datatable_name=tablename
    conn = pymysql.connect(server_name, user_name, user_password, database_name, charset="utf8")
    cursor=conn.cursor()
    sql="show tables like '"+tablename+"'"
    cursor.execute(sql)
    result=cursor.fetchall()
    if len(result) ==0:
        sql="create table "+tablename+"( "\
                "student_number varchar(13) not null,"\
                "BH varchar(2),"\
                "exam_taker_number varchar(20),"\
                "name varchar(11),"\
                "gender varchar(8),"\
                "birthday varchar(8),"\
                "faculty varchar(23),"\
                "discipline varchar(47),"\
                "length_of_academic_system varchar(2),"\
                "checked_time varchar(255),"\
                "photo varchar(255), "\
                "primary key(student_number)) charset=utf8"
        cursor.execute(sql)
        conn.commit()
        xlsfile = xlrd.open_workbook(file)
        sheet = xlsfile.sheet_by_index(0)
        nrows = sheet.nrows
        print(nrows)
        index = 1
        while index < nrows:
            print(index)
            value = [0 for i in range(11)]
            for i in range(9):
                value[i] = sheet.cell(index, i).value
            value[9] = ""
            value[10] = ""
            sql="insert into "+tablename+\
                " values('"+value[0]+"','"+value[1]+"','"+value[2]+"','"+value[3]+"','"+value[4]+"',"\
                "'"+value[5]+"','"+value[6]+"','"+value[7]+"','"+value[8]+"','"+value[9]+"',"\
                "'"+value[10]+"')"
            cursor.execute(sql)
            conn.commit()
            index += 1
        tkinter.messagebox.showinfo('成功', '数据表导入成功')
    else:
        pass
    sql="select * from "+tablename+" limit 1"
    cursor.execute(sql)
    student = Student(cursor.fetchone())  # 尝试把查询结果绑定到Student对象
    sql = "select count(*) from " + datatable_name
    cursor.execute(sql)
    student.sum = cursor.fetchone()[0]
    student.rank=1
    conn.close()
    showinfo(student)
最佳答案
2020-5-8 20:08:04
本帖最后由 jkluoling1992 于 2020-5-8 20:30 编辑

把while内的conn. commit写到while循环外
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-5-8 17:30:01 | 显示全部楼层
有人吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-8 19:50:31 | 显示全部楼层
有人吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-8 20:08:04 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
本帖最后由 jkluoling1992 于 2020-5-8 20:30 编辑

把while内的conn. commit写到while循环外
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-8 23:11:15 | 显示全部楼层
jkluoling1992 发表于 2020-5-8 20:08
把while内的conn. commit写到while循环外

感谢大佬,解决了!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-27 05:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表