python异步库_python 异步MySQL存库

# 用twisted库将数据进行异步插入到数据库

import pymysql

from twisted.enterprise import adbapi

from twisted.internet import reactor

class MysqlTwistedPipeline(object):

def __init__(self, dbpool):

self.dbpool = dbpool

@classmethod

def from_settings(cls, settings):

# 需要在setting中设置数据库配置参数

dbparms = dict(

host=settings['MYSQL_HOST'],

db=settings['MYSQL_DBNAME'],

user=settings['MYSQL_USER'],

passwd=settings['MYSQL_PASSWORD'],

charset='utf8',

cursorclass=pymysql.cursors.DictCursor,

use_unicode=True,

)

# 连接ConnectionPool(使用MySQLdb连接,或者pymysql)

dbpool = adbapi.ConnectionPool("MySQLdb", **dbparms) # **让参数变成可变化参数

return cls(dbpool) # 返回实例化对象

def process_item(self, item, spider):

# 使用twisted将MySQL插入变成异步执行

query = self.dbpool.runInteraction(self.do_insert, item)

# 添加异常处理

query.addCallback(self.handle_error)

def handle_error(self, failure):

# 处理异步插入时的异常

print(failure)

def do_insert(self, cursor, item):

# 执行具体的插入

insert_sql = """

insert into jobbole_artitle(name, base_url, date, comment)

VALUES (%s, %s, %s, %s)

"""

cursor.execute(insert_sql, (item['name'], item['base_url'], item['date'], item['coment'],))

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值