木三136 2021-04-07 15:36 采纳率: 78.9%
浏览 60
已结题

python 连接数据库是遇到的问题

先看代码

class mysqlPipeline(object):
    conn = None
    cursor = None

    # 连接数据库
    def opens_spider(self, spider):
        self.conn = pymysql.Connect(host='127.0.0.1', port=3306, user='root', password='123456', db='test',
                                    charset='utf8')

    def process_item(self, item, spider):
        self.cursor = self.conn.cursor()
        try:
            self.cursor.execute('insert into qiubai values("%s","%s")' % (item["author"], item["content"]))
            self.conn.commit()
        except Exception as e:
            print(e)
            self.conn.rollback()  # 回滚
        return item

    def close_spider(self, spider):
        self.cursor.close()
        self.conn.close()

这是错误提示

AttributeError: 'NoneType' object has no attribute 'close'

我猜测是使用数据库进行连接是出了问题,但是不知道怎么改,请大佬们看看,谢谢

  • 写回答

3条回答 默认 最新

  • 天元浪子 Python领域优质创作者 2021-04-07 16:13
    关注

    题主的这一部分代码无助于定位问题。猜测大概是代码某处调用了close_spider方法,而当时的conn或者cursors是None,因此才会抛出'NoneType' object has no attribute 'close'

    另外,将conn或者cursors定义为mysqlPipeline类的静态变量,是一个比较罕见的做法。通常,类的静态变量一般用于保存类的静态属性,该属性可被类的方法使用,但不应该被类的方法修改。类名首字母大写,也是约定俗成的规则,模块名则是小写字母开头。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月11日
  • 已采纳回答 2月3日

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测