У меня есть python script, который читает текстовые файлы raw movie в базу данных sqlite.
Я использую re.escape(title), чтобы добавить escape-символы в строки, чтобы сделать их db безопасными перед выполнением вставок.
Почему это не работает:
In [16]: c.execute("UPDATE movies SET rating = '8.7' WHERE name='\'Allo\ \'Allo\!\"\ \(1982\)'")
--------------------------------------------------------------------------- OperationalError Traceback (most recent call last)
/home/rajat/Dropbox/amdb/<ipython console> in <module>()
OperationalError: near "Allo": syntax error
Но это работает (удаляется\в двух местах):
In [17]: c.execute("UPDATE movies SET rating = '8.7' WHERE name='Allo\ Allo\!\"\ \(1982\)'") Out[17]: <sqlite3.Cursor object at 0x9666e90>
Я не могу понять. Я также не могу сорвать эти ведущие цитаты, потому что они на самом деле являются частью названия фильма. Спасибо.