我正在尝试使用selenium和beautifulsoup抓取网页,然后将结果存储到mysql。结果包含许多特殊字符,如;'“=(因为它正在解析html)
我遵循了mysql连接器/python和insert的工作原理,但是更新了。
如果我选择我的表,我可以看到这样的东西
<div style="width:80px; float: ~~~ ... </div>
这意味着目标html元素已成功存储。这是我的插入和更新。
# after import and configs
soup = BeautifulSoup(innerHTML, "html.parser")
text = soup.prettify()
print(text)
# this INSERT works fine
# insert = ("INSERT INTO g_cache (a_col, cache_contents) VALUES(%s, %s)")
# data_row = ('aaa', text)
# cursor.execute(insert, data_row)
# Trying to UPDATE already inserted row. Not working
# I executed and commented above INSERT before run the following UPDATE
update = ("""UPDATE g_cache SET cache_contents =%s WHERE id=21""")
data_col = (text)
cursor.execute(update, data_col)
# If I use one complete string, it works though. For example
# cursor.execute("""UPDATE g_cache SET cache_contents ='111' WHERE id=21""")
cnx.commit()
错误消息为
mysql.connector.errors.programmingerror:1064(42000):您的sql语法有错误;请查看与您的mysql服务器版本对应的手册,以获取在第1行的“%s where id=21”附近使用的正确语法
我刚刚介绍了mysql::connector/pythonapi。
我不明白为什么insert可以工作,而update不能,使用相同的字符串。
有人知道吗??
1条答案
按热度按时间wxclj1h51#
参数必须作为Map(即dict)或元组传递。在只传递一个参数时省略尾随逗号会将其视为标量,因此必须按如下方式传递参数:
文件还提到,在一个突出的说明。