首页 > 编程问答 >将情感分析中的值插入数据库

将情感分析中的值插入数据库

时间:2024-07-28 07:01:57浏览次数:8  
标签:python sql postgresql psycopg2

我自己创建了一个小项目:

用户在网站上输入一些评论,然后使用flask+python我们获取这些文本,在变压器和所有结果的帮助下将其发送到情感分析(文本,标签,分数)插入 Postgresql

这个项目分为两个主要部分,首先我在数据库中创建了空表:

CREATE TABLE Message_sentiment (
    mytext text,
    text_label text,
    score numeric
);

基于第二部分,这是我的小代码:

if request.method=='POST':
    text =request.form.get('user_comment')
    label =model(text)[0]['label']
    score =model(text)[0]['score']
    # print(f'{text} has  following label {label} with score {score}')
    curr.execute("""INSERT INTO message_sentiment(mytext,text_label,score) VALUES
    (text,label, score)
    """)

当我运行此代码时,得到以下内容错误:

UndefinedColumn
psycopg2.errors.UndefinedColumn: column "text" does not exist
LINE 2:         (text,label, score)
                 ^
HINT:  Perhaps you meant to reference the column "message_sentiment.mytext".

所以我认为问题出在这里:

 curr.execute("""INSERT INTO message_sentiment(mytext,text_label,score) VALUES
        (text,label, score)
        """)

我不能使用 {} 括号,请帮助我如何修改这一行?提前致谢


问题在于你的 SQL 语句中,你把变量名当作了字符串。你需要使用占位符,然后将变量值传递给 execute 方法。

修改后的代码如下:

if request.method == 'POST':
    text = request.form.get('user_comment')
    label = model(text)[0]['label']
    score = model(text)[0]['score']
    # print(f'{text} has  following label {label} with score {score}')
    curr.execute(
        """INSERT INTO message_sentiment (mytext, text_label, score) VALUES (%s, %s, %s)""",
        (text, label, score),
    )

解释:

  1. 占位符: 在 SQL 语句中,我们使用 %s 作为占位符,表示这里需要插入一个值。
  2. 传递变量: execute 方法中,第二个参数是一个元组,包含了要插入的值,按照占位符的顺序对应。

这样,psycopg2 就会将变量的值安全地插入到 SQL 语句中,避免了将变量名误认为是字符串的问题。

标签:python,sql,postgresql,psycopg2
From: 78802634

相关文章

  • 当读取字节时,Python 将 \n 解释为 0xd0
    换行符被解释为Ð(0xd0)而不是(0x0a),我真的不知道如何解决这个问题。我也不知道从哪里开始。当尝试使用此代码时,它将0x0a读为0xd0。withopen(path,"rb")asroot:b_arr=root.read()+b""print("Processing...")buffer=""b_arr......
  • 在Python 3中获取范围的特定形式
    当获取range(1,100)时,我得到:[1,2,3,4,5...99]我需要像这个范围的zip之类的东西:[50,49,51,48,52,47,53...99]如何获取它?背景:这都是关于比特币谜题66的。首先我做了对过去已知的私钥进行线性回归预测,直到第65题为止。我......
  • Python:如何使用pyaudio或sounddevice等库进行自动录音?
    我想做一个项目,需要满足以下录音要求:程序启动后,会在后台不断检测麦克风的声音,当声音分贝大于一定值时打开录音流级别,当分贝低于一定级别时关闭录音流并保存为wav文件。我知道原理,但我无法使用这些库来实现。我想实现以上结果使用Python实现自动录音以下代......
  • 当我们创建一个在 https 服务器上获取和发送数据的 python 应用程序时,我们应该如何处
    python脚本使用Urllib3,我的服务器是在Node.js上编写的脚本。我担心(并且不清楚)证书:我是否需要将我的python应用程序上的证书另存为变量?例如我这样做了,http=urllib3.PoolManager(cert_reqs="CERT_REQUIRED",ca_certs='client-cert.pem')并且我不知道......
  • 使用 Python 进行 Web 抓取以获取数据 NoneType ERROR
    我正在努力为我的学校项目获取美元和价格。所以我决定为此使用网络抓取,但我有一个问题。当我尝试在服务器上使用我的代码时,它给我NoneType错误。它可以在googlecolab上使用,但我无法在我的电脑或服务器上使用。我该如何解决这个问题?网页抓取代码;defdolar():he......
  • Python 请求 - response.json() 未按预期工作
    我正在尝试从Python的requests模块调用API。在邮递员上,返回的响应标头中的Content-Type是application/json;charset=utf-8,响应json数据是我期望的样子。但是,在python上的API的get方法之后运行response.json()会抛出错误simplejson.errors......
  • Python 中的“样板”代码?
    Google有一个Python教程,他们将样板代码描述为“不幸的”,并提供了以下示例:#!/usr/bin/python#importmodulesusedhere--sysisaverystandardoneimportsys#Gatherourcodeinamain()functiondefmain():print'Hellothere',sys.argv[1]#Command......
  • Python 3.9.1 中的 collections.abc.Callable 是否有 bug?
    Python3.9包含PEP585并弃用typing模块中的许多类型,转而支持collections.abc中的类型,现在它们支持__class_getitem__例如Callable就是这种情况。对我来说,typing.Callable和collections.abc.Ca......
  • 列表子类的 Python 类型
    我希望能够定义列表子类的内容必须是什么。该类如下所示。classA(list):def__init__(self):list.__init__(self)我想包含键入内容,以便发生以下情况。importtypingclassA(list:typing.List[str]):#Maybesomethinglikethisdef__init__(self):......
  • Python 中类型友好的委托
    考虑以下代码示例defsum(a:int,b:int):returna+bdefwrap(*args,**kwargs):#delegatetosumreturnsum(*args,**kwargs)该代码运行良好,只是类型提示丢失了。在Python中使用*args,**kwargs来实现​​委托模式是很常见的。如果有一种方法可......