python - 将 Excel Oracle DB 查询转换为 Python Pandas

标签 python sql excel database oracle

我有一个简单的程序,可以在 Python 中与 Oracle DB 建立连接。我需要一些关于如何在 Python 中编写 SQL 查询的提示。我有一个工作正常的 Excel 查询,但我在 Python 中需要它,我认为我在 Excel 查询连接属性中有我需要的东西。我的 python 程序看起来像这样-

import pandas as pd
import cx_Oracle
from sys import exit

conn= cx_Oracle.connect('DOMINA_CO/S#UU@ex021-orc.corp.mycompany.com:1540/domp_domi_bi')
try:
    query = '''
     SELECT * from dual
         '''
    df = pd.read_sql(con = conn, sql = query)
    finally:
conn.close()
df.head()

exit()
并返回 -
Out[2]: 
DUMMY
0     X
在 Excel 中,我有工作查询的连接属性,它具有如下所示的“命令文本:”:
SELECT TO_CHAR (DGE_DATOS_INSTALACIONES.FEC_LOCAL - (1/24), 'YYYY-MM') MONTH,
       REPLACE(DGE_NEGOCIOS.NOM_NEGOCIO, 'ESPAÑA', 'SPAIN') BUSINESS,
       REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(DGE_PAISES.NOM_PAIS, 'ESPAÑA', 'SPAIN'), 'ALEMANIA', 'GERMANY'), 'BRASIL', 'BRAZIL'), 'CHIPRE', 'CYPRUS'), 'FRANCIA', 'FRANCE'), 'GRECIA', 'GREECE'), 'HUNGRIA', 'HUNGARY'), 'ITALIA', 'ITALY'), 'POLONIA', 'POLAND'), 'RUMANIA', 'ROMANIA'), 'ESCOCIA', 'SCOTLAND'), 'GALES', 'WALES'), 'INGLATERRA', 'ENGLAND'), 'IRLANDA DEL NORTE', 'NORTHERN IRELAND'), 'IRLANDA', 'IRELAND'), 'ESTADOS UNIDOS', 'UNITED STATES') COUNTRY,
       DGE_REGIONES.NOM_REGION REGION,
       DGE_INSTALACIONES.NOM_INSTALACION PARK,
       ROUND(SUM(DGE_DATOS_INSTALACIONES.CAN_PRODUCIBLE_SUMA*DGE_DATOS_INSTALACIONES.COEF_PERDIDAS_MEDIA_TENSION*DGE_DATOS_INSTALACIONES.COEF_PERDIDAS_PF)/1000) "POTENTIAL_GEN_(MWH)"

FROM DOMINAGE.DGE_DATOS_INSTALACIONES DGE_DATOS_INSTALACIONES,
     DOMINAGE.DGE_NEGOCIOS DGE_NEGOCIOS,
     DOMINAGE.DGE_PAISES DGE_PAISES,
     DOMINAGE.DGE_REGIONES DGE_REGIONES,
     DOMINAGE.DGE_INSTALACIONES DGE_INSTALACIONES

WHERE DGE_DATOS_INSTALACIONES.FEC_LOCAL >= TO_DATE('01-JAN-13 01:00', 'DD-MON-YY HH24:MI')
      AND DGE_DATOS_INSTALACIONES.COD_INSTALACION = DGE_INSTALACIONES.COD_INSTALACION
      AND DGE_INSTALACIONES.COD_NEGOCIO = DGE_NEGOCIOS.COD_NEGOCIO
      AND DGE_INSTALACIONES.COD_PAIS = DGE_PAISES.COD_PAIS
      AND DGE_INSTALACIONES.COD_REGION = DGE_REGIONES.COD_REGION

GROUP BY TO_CHAR (DGE_DATOS_INSTALACIONES.FEC_LOCAL - (1/24), 'YYYY-MM'),
         DGE_NEGOCIOS.NOM_NEGOCIO,
         DGE_PAISES.NOM_PAIS,
         DGE_REGIONES.NOM_REGION,
         DGE_INSTALACIONES.NOM_INSTALACION

ORDER BY MONTH,
         REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(BUSINESS, 'UNITED STATES', '1'), 'SPAIN', '2'), 'UNITED KINGDOM', '3'), 'INTERNATIONAL', '4'), 'OFFSHORE', '5'),
         COUNTRY,
         PARK
非常感谢将此查询转换为 python 查询的任何帮助,因为我对在 python 中编写数据库查询非常陌生!

最佳答案

不需要翻译。只需重新运行相同的查询。 Python 和 Excel VBA 作为客户端应用程序连接到相同的后端数据库,这里是 Oracle。数据库旨在连接到任何客户端。
事实上,考虑将长 SQL 查询保存在文本 .sql 中。文件并让所有客户端简单地读取脚本文件并避免在任一代码中使用引号或换行符的长字符串。
python

conn= cx_Oracle.connect('...')

# READ SQL QUERY FROM FILE
with open(r'C:\path\to\my\query.sql') as f:
    query = f.read().strip()

# IMPORT INTO PANDAS DATA FRAME
try:
    df = pd.read_sql(con = conn, 
                     sql = query)     # QUERY READ FROM .sql FILE
finally:
    conn.close()

df.head()
Excel VBA
' READ SQL QUERY FROM FILE
With CreateObject("Scripting.FileSystemObject")
      sql = .OpenTextFile("C:\Path\To\my\query.sql", 1).readall
End With

' OPEN DB CONNECTION
Set conn = New ADODB.Connection
conn.Open "..."
   
' DEFINE COMMAND OBJECT
Set cmd = New ADODB.Command
With cmd
    .ActiveConnection = conn
    .CommandType = adCmdText
    .CommandText = sql               ' QUERY READ FROM .sql FILE
    
    Set rst = cmd.Execute
End With 

关于python - 将 Excel Oracle DB 查询转换为 Python Pandas,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65362852/

相关文章:

python - django syncdb 通过后 Heroku 出现 "no such table"错误

python - 如何使用 Python 库获取 Facebook 访问 token ?

Python tkinter - 成功从顶层继承

mysql - 如何删除除最近行以外的所有其他列相同的行

sql - 如何获取 SQL Server 中每个组/分区的最大行数?

excel - 如何使用 EXCEL 公式从一列单元格中提取具有特定模式的文本?

excel - 如何在Excel中创建后退按钮以将用户移动到他原来的位置?

python - Sublime 3,带有参数和返回的 python 函数文档字符串的片段

mysql - 如何在这个简单的查询中避免文件排序? (没有加入)

vba - 使用 Windows Socket 和 Excel VBA 的轻客户端