Is there a way with pandas to use read_sql() with an sql-statement, that takes multiple variables?(对于 pandas 来说,有没有办法将Read_SQL()与接受多个变量的SQL语句一起使用?)
本文介绍了对于 pandas 来说,有没有办法将Read_SQL()与接受多个变量的SQL语句一起使用?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
这是我代码的一部分。我已经有了一个包含值的数据库,需要根据该数据框中的值创建一个新的数据框(目前这些值只有12&;13,存储在header_row_ids变量中)。
当我运行该脚本时,收到以下错误消息:
pandas.io.sql.DatabaseError:对SQL‘SELECT*FROM dbo.TestDetails WHERE ID IN(?,?),(13,12)’:(‘07002’,‘[07002][Microsoft][ODBC SQL Server驱动程序]计数字段不正确或语法错误’)执行失败
有人能帮我解决这个问题吗?我将非常感激。
import pypyodbc
import pandas
sourceConnection = pypyodbc.connect(
self.sourceDriver +
self.sourceServer +
self.sourceDatabase
)
placeholders = ",".join("?" * (len(self.header_row_ids)))
sql_source_detail_select = "SELECT * FROM dbo.TestDetails WHERE Id IN (%s)" % placeholders
header_row_ids = [12, 13]
header_row_ids_string = str(self.header_row_ids).strip('[]')
new_sql_source_detail_select = sql_source_detail_select + ", (" + header_row_ids_string + ")"
dataframe = pandas.read_sql(new_sql_source_detail_select, sourceConnection)
推荐答案
read_sql接受可用于传递参数值的params参数:
# header_row_ids = [12, 13]
# sql = "SELECT * FROM dbo.TestDetails WHERE Id IN (?,?)"
dataframe = pandas.read_sql(sql, sourceConnection, params=header_row_ids)
这篇关于对于 pandas 来说,有没有办法将Read_SQL()与接受多个变量的SQL语句一起使用?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:对于 pandas 来说,有没有办法将Read_SQL()与接受多个变量的SQL语句一起使用?
基础教程推荐
猜你喜欢
- matplotlib 设置 yaxis 标签大小 2022-01-01
- kivy 应用程序中的一个简单网页作为小部件 2022-01-01
- 对多索引数据帧的列进行排序 2022-01-01
- 究竟什么是“容器"?在蟒蛇?(以及所有的 python 容器类型是什么?) 2022-01-01
- Kivy 使用 opencv.调整图像大小 2022-01-01
- 比较两个文本文件以找出差异并将它们输出到新的文本文件 2022-01-01
- 在 Django Admin 中使用内联 OneToOneField 2022-01-01
- 在 Python 中将货币解析为数字 2022-01-01
- Python 中是否有任何支持将长字符串转储为块文字或折叠块的 yaml 库? 2022-01-01
- Python,确定字符串是否应转换为 Int 或 Float 2022-01-01
