Python调用SQLPlus来 *** 作和解析Oracle数据库的方法

Python调用SQLPlus来 *** 作和解析Oracle数据库的方法,第1张

概述先来看一个简单的利用python调用sqlplus来输出结果的例子:importosimportsysfromsubprocessimportPopen,PIPE

先来看一个简单的利用python调用sqlplus来输出结果的例子:

import osimport sysfrom subprocess import Popen,PIPE sql = """set linesize 400col owner for a10col object_name for a30 select owner,object_name from dba_objects where rownum<=10;""" proc = Popen(["sqlplus","-S","/","as","sysdba"],stdout=PIPE,stdin=PIPE,stderr=PIPE)proc.stdin.write(sql)(out,err) = proc.communicate() if proc.returncode != 0:  print err  sys.exit(proc.returncode)else:  print out

用Python查询Oracle,当然最好用cx_Oracle库,但有时候受到种种限制,不能安装Python第三方库,就得利用现有资源,硬着头皮上了。

用Python调用sqlPlus查询Oracle,首先要知道sqlPlus返回结果是什么样的:

(这是空行)Number    name    Address------------ ----------- ------------------1001     张三     南京路1002     李四     上海路

第1行是空行,第2行是字段名称,第3行都是横杠,有空格隔开,第4行开始是查询到的结果。

在查询结果规整的情况下,根据第3行可以很清晰的看到结构,用Python解析起来也比较方便。但是,如果一张表字段特别多,记录数也相当多,那么默认情况下调用sqlPlus查询出的结果会比较乱,这就需要在调用查询之前做一些设定,比如:

set linesize 32767set pagesize 9999set term off verify off Feedback off tab offset numwIDth 40

这样的调用查询结果就比较规整了。接下来就是用强大的Python来解析查询结果。

这里封装了一个函数,可以根据传入的SQL语句查询并解析结果,将每行结果存到列表中,列表中的每个元素是一个字段名称与值的映射。

#!/usr/bin/python#Coding=UTF-8'''@author: 双子座@开源中国@summary: 通过sqlPlus查询Oracles数据库'''import os;os.environ['NLS_LANG'] = 'AMERICAN_AMERICA.AL32UTF8'gStrConnection = 'username/[email protected]:1521/ora11g'#解析sqlPlus的查询结果,返回列表def parsequeryResult(ListqueryResult):  ListResult = []  #如果少于4行,说明查询结果为空  if len(ListqueryResult) < 4:    return ListResult  #第0行是空行,第1行可以获取字段名称,第2行可获取sqlPlus原始结果中每列宽度,第3行开始是真正输出  # 1 解析第2行,取得每列宽度,放在列表中  ListStrTmp = ListqueryResult[2].split(' ')  ListIntWIDth = []  for onestr in ListStrTmp:    ListIntWIDth.append(len(onestr))  # 2 解析第1行,取得字段名称放在列表中  ListStrFIEldname = []  iLastIndex = 0  lineFIEldnames = ListqueryResult[1]  for iWIDth in ListIntWIDth:    #截取[iLastIndex,iLastIndex+iWIDth)之间的字符串    strFIEldname = lineFIEldnames[iLastIndex:iLastIndex + iWIDth]    strFIEldname = strFIEldname.strip() #去除两端空白符    ListStrFIEldname.append(strFIEldname)    iLastIndex = iLastIndex + iWIDth + 1  # 3 第3行开始,解析结果,并建立映射,存储到列表中  for i in range(3,len(ListqueryResult)):    oneliseResult = unicode(ListqueryResult[i],'UTF-8')    fIEldMap = {}    iLastIndex = 0    for j in range(len(ListIntWIDth)):      strFIEldValue = oneliseResult[iLastIndex:iLastIndex + ListIntWIDth[j]]      strFIEldValue = strFIEldValue.strip()      fIEldMap[ListStrFIEldname[j]] = strFIEldValue      iLastIndex = iLastIndex + ListIntWIDth[j] + 1    ListResult.append(fIEldMap)  return ListResultdef queryBysqlPlus(sqlCommand):  global gStrConnection  #构造查询命令  strCommand = 'sqlplus -S %s <<!\n' % gStrConnection  strCommand = strCommand + 'set linesize 32767\n'  strCommand = strCommand + 'set pagesize 9999\n'  strCommand = strCommand + 'set term off verify off Feedback off tab off \n'  strCommand = strCommand + 'set numwIDth 40\n'  strCommand = strCommand + sqlCommand + '\n'  #调用系统命令收集结果  result = os.popen(strCommand)  List = []  for line in result:    List.append(line)  return parsequeryResult(List)

其中os.environ['NLS_LANG']的值来自

@H_419_33@select userenv['language'] from dual;在调用的时候,只要类似:@H_419_33@ListResult = queryBysqlPlus('select * from studentinfo')

然后就可以用循环打印出结果了。

总结

以上是内存溢出为你收集整理的Python调用SQLPlus来 *** 作和解析Oracle数据库的方法全部内容,希望文章能够帮你解决Python调用SQLPlus来 *** 作和解析Oracle数据库的方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/langs/1204235.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存