pymysql - python3.5操作数据库中fetchall的问题
ringa_lee
ringa_lee 2017-04-18 09:43:49
[Python讨论组]

import pymysql.cursors
import networkx as nx

Connect to the database

connection = pymysql.connect(host='localhost',

                         port=3306,
                         user='root',
                         password='',
                         db='shortest',
                         charset='utf8mb4',
                         cursorclass=pymysql.cursors.DictCursor)

执行sql语句

try:

    cursor = connection.cursor()
    # 执行sql语句,进行查询
    sql = 'SELECT author1,author2,year FROM shortest WHERE id < 200'
    cursor.execute(sql)
    # 获取查询结果
    result = cursor.fetchall()
    for row in result:
        author1 = row[1]
        author2 = row[2]
        year = row[3]
        # 打印结果
        print
        "auther1=%s,author2=%s,year=%s" % \
        (myauther1, myauther2, myyear)
    # 没有设置默认自动提交,需要主动提交,以保存所执行的语句
    connection.commit()

finally:

connection.close();

这个代码我感觉没有问题,但是编译器却报错!!!
Traceback (most recent call last):
File "E:/Python Work/beta1/test.py", line 21, in <module>

author1 = row[1]

KeyError: 1

希望高手可以解释指点一下,谢谢啦!

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
迷茫

应该是result是一个字典结构,在python中需要用dict['Name']这样的形式使用吧。具体可百度字典用法。

迷茫

你先把result打印出来试试

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号