使用 python 在 sql 查询中从文本文件中调用日期

Calling date from text file in sql query using python

我正在尝试使用 python 将外部文本文件中的日期输入到 sql 查询中 下面是我的代码:

import cx_Oracle
import pandas as pd
import numpy as np
dsn_tns = cx_Oracle.makedsn(ip, port,service_name = SERVICE_NAME)

db = cx_Oracle.connect('username', 'password', dsn_tns)
curs = db.cursor()

with open("Date.txt") as file:
log=file.read().splitlines()
import datetime
var1=datetime.datetime.strptime(log[0], "%d-%b-%Y %H:%M:%S").strftime("%d-%b-%Y %H:%M:%S")
var2=datetime.datetime.strptime(log[1], "%d-%b-%Y %H:%M:%S").strftime("%d-%b-%Y %H:%M:%S")

query = curs.execute("""SELECT * from table_name where cr_date >= TO_DATE(%s,'DD-MON-YYYY HH24:MI:SS') AND cr_date < to_date(%s,'DD-MON-YYYY HH24:MI:SS')""", (var1, var2))

from pandas import DataFrame
df = DataFrame(query.fetchall())

在这里,我将查询与 Oracle 连接,然后尝试将 Date.txt 中的日期插入到 SQL 查询中,其中包括如下两个日期:

27-DEC-2018 00:00:00
26-JAN-2019 00:00:00

然后我想将我的结果保存到数据框 df 中,但是在从文本文件中插入日期时出现以下错误。

Traceback (most recent call last): File "C:\Users\ab\Desktop\oracle_connect.py", line 24, in <module> AND cr_date < to_date(%s,'DD-MON-YYYY HH24:MI:SS')""", (var1, var2)) cx_Oracle.DatabaseError: ORA-01036: illegal variable name/number

请建议我需要对 运行 这段代码做哪些更改。另外让我知道我的数据框 df 是否也拉了列 header,因为目前我正在插入列 header 与其他代码分开。提前致谢

cx_oracle 采用“:1、:2、:3”或字典形式的绑定变量。

尝试将绑定变量的“%s”位置更改为“:1”和“:2”。这就是我一直在 oracle 中进行绑定的方式。不确定它会解决任何问题。当然去掉 "s.

你也可以用字典来做到这一点,让它成为“:val1”和“:val2”,然后传入一个字典而不是像 {"val1":"something" 这样的列表, "val2":"something2"}