Discord bot 脚本在 vps 中无法正常工作?

问题描述

我已将我的 discord bot python 脚本上传到我的 vps,但它无法正常工作。 我收到错误

File "/root/cogs/zaidimas.py",line 426,in atnaujinti
cursor.execute(f"UPDATE misijos SET laikasmisija = {laikutis-3} WHERE userid                        ={zaidikas}")                                                                                     
TypeError: unsupported operand type(s) for -: 'str' and 'int'

而在 Windows 中我没有收到此错误,这是导致错误代码

@tasks.loop(seconds=3.0)
async def atnaujinti(self):
    db=sqlite3.connect('misija.sqlite')
    cursor = db.cursor()
    cursor.execute(f"SELECT userid FROM misijos")
    for zaidejas in cursor.fetchall():
        zaidikas=zaidejas[0]
        cursor.execute(f"SELECT laikasmisija FROM misijos WHERE userid={zaidikas}")
        laikas=cursor.fetchone()
        laikutis=laikas[0]
        db.commit()
        cursor.execute(f"UPDATE misijos SET laikasmisija = {laikutis-3} WHERE userid={zaidikas}")
    db.commit()

在我将 laikutis 和 zaidimas 放入 int( ) 后,错误消失了,但其他每一行代码也需要像这样更改,我从未在 Windows 中遇到过这些错误代码运行良好。

vps 是 ubuntu 20.04,python 3.9.1,discord py 1.6 我用'python3.9 taisykliuBot.py'运行代码(taisykliuBot.py是主脚本) 这里可能有什么问题,或者我需要去更改脚本中的所有值?

编辑:我的观点是相同的代码在 Windows 中可以完美编译,但在 ubuntu 上它给了我错误。没有更简单的方法吗?

解决方法

将其转换为 Łukasz 所说的 int。

cursor.execute(f"UPDATE misijos SET laikasmisija = {int(laikutis)-3} WHERE userid={zaidikas}")